首页 > 其他 > 详细

第六周编程总结

时间:2019-04-05 14:41:41      阅读:138      评论:0      收藏:0      [点我收藏+]

技术分享图片

函数fun的功能是:求两数平方根之和,作为函数值返回。例如:输入12和20,输出结果是:y = 7.936238。
函数接口定义:
double fun (double a, double b);
其中 a和 b是用户传入的参数。函数求 a指针和b 指针所指的两个数的平方根之和,并返回和。
裁判测试程序样例:

include<stdio.h>

include <math.h>

double fun (double a, double b);
int main ( )
{ double a, b, y;
scanf ("%lf%lf", &a, &b );
y=fun(&a, &b); printf ("y=%.2f\n", y );
return 0;
}
/* 请在这里填写答案 */
输入样例:
12 20
输出样例:
y=7.94

1.实验代码

double fun(doublea,doubleb)
{
double c,d,result;
c=sqrt(a);
d=sqrt(
b);
result=c+d;
return result;
}

2.设计思路
技术分享图片

3.运行结果
技术分享图片

读入n个整数,调用max_min()函数求这n个数中的最大值和最小值。
输入格式:
输入有两行: 第一行是n值; 第二行是n个数。
输出格式:
输出最大值和最小值。
输入样例:
在这里给出一组输入。例如:
5
8 9 12 0 3
输出样例:
在这里给出相应的输出。例如:
max = 12
min = 0

1.实验代码

include<stdio.h>

include<string.h>

void max_min(int a[],int len,int* pmax,int* pmin);
int main(){
int n,i,max,min,len=0;
int pmax,pmin;
int a[10000];
scanf("%d",&n);
for(i=0;i<n;i++){
scanf("%d",&a[i]);
len++;
}
max_min(a,len,&max,&min);
printf("max = %d\nmin = %d",max,min);
return 0;
}
void max_min(int a[],int len,int* pmax,int* pmin){
int i;
pmax=a[0];
pmin=a[0];
for(i=1;i<len;i++){
if(pmax<a[i]) pmax=a[i];
if(pmin>a[i]) pmin=a[i];
}
}

2.设计思路
技术分享图片

3.运行结果
技术分享图片

为一维数组输入10个整数;将其中最小的数与第一个数对换,将最大的数与最后一个数对换;输出数组元素。。
函数接口定义:
void input(int arr,int n);
void max_min(int
arr,int n);
void output(int *arr,int n);
三个函数中的 arr和n 都是用户传入的参数。n 是元素个数。
input函数的功能是输入 n个元素存到指针arr所指向的一维数组中。
max_min函数的功能是求指针arr所指向的一维数组中的最大值和最小值,其中最小的数与第一个数对换,将最大的数与最后一个数对换。
output函数的功能是在一行中输出数组元素,每个元素输出占3列。
裁判测试程序样例:

include<stdio.h>

void input(int arr,int n);
void max_min(int
arr,int n);
void output(int *arr,int n);
int main()
{ int a[10];
input(a,10);
max_min(a,10);
output(a,10);
return 0;
}

/* 请在这里填写答案 */
输入样例:
5 1 4 8 2 3 9 5 12 7
输出样例:
1 5 4 8 2 3 9 5 7 12

1.实验代码

void input(int *arr,int n)
{
  for(int i=0;i<n;i++)
  {
    scanf("%d",&arr[i]);
  }
}
void max_min(int *arr,int n)
{
  int i,max,min,temp;
  for(i=1;i<n;i++)
  {
    if(arr[i]>arr[max])
      max=i;
    if(arr[i]<arr[min])
      min=i;
  }
  temp=arr[max];
  arr[max]=arr[9];
  arr[9]=temp;
  temp=arr[0];
  arr[0]=arr[min];
  arr[min]=temp;
}
void output(int *arr,int n)
{
  for(int i=0;i<n;i++)
  {
    printf("%3d",arr[i]);
  }
}

2.设计思路
技术分享图片

3.运行结果图
技术分享图片

遇到的问题及解决方法
1.对指针的定义模糊,还无法灵巧地运用,需要花更多的时间认识指针
2.对以前学过的知识有些遗忘需要重温
技术分享图片

第六周编程总结

原文:https://www.cnblogs.com/shsy/p/10658563.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!