第六周編程總結
6-1 求兩數平方根之和 (10 分)
函數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 );
return 0;
}
(1)實驗代碼
double fun (double a, double b)
{
double sum;
sum=sqrt(a)+sqrt(b);
return sum;
}
(2)設計思路:首先定義浮點型a,b,sum然後進入公式再運行,再然後結束sum。
(3)運行截圖
7-1 利用指針返回多個函數值 (30 分)
讀入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]);
}
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)設計思路:首先定義整形max,min,len,pmax,pmin,a[1000],然後進入循環使得len++,再 if(pmax<a[i]) pmax=a[i];if(*pmin>a[i】。
(3)流程圖
(4)遇到問題及解決方法
問題一:指針與函數二者混合運用,導致編譯錯誤;
解決方法:找同學幫忙。
問題二:將最大值與最小值都賦值為0,但是運行時錯誤,到Dev-C++上運行時,發現如果輸入數組中無比0小的值,它就會自動輸出0,導致錯誤;
解決方法:重新規劃思路,找同學幫忙。
(5)運行截圖
6-3 最小數放前最大數放後 (10 分)
為一維數組輸入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 max, min, med;
max=min=arr[0];
for(int i=0;i<n;i++)
{
if(max<arr[i])
max=i;
if(min>arr[i])
min=i;
}
med=arr[max];
arr[max]=arr[n-1];
arr[n-1]=med;
med=arr[0];
arr[0]=arr[min];
arr[min]=med;
}
void output(int arr,int n)
{
for(int i=0;i<n;i++)
{
printf("%3d",arr[i]);
}
}
(2)設計思路:首先定義整形arr,max,min,med,然後進入循環如果max<arr[i]則max=i否則min=i再然後med=arr[max];
arr[max]=arr[n-1];
arr[n-1]=med;
med=arr[0];
arr[0]=arr[min];
arr[min]=med;
(3)遇到問題及解決方法
問題一:最大的問題就是自己粗心導致編譯錯誤。
解決方法:從新看源代碼,找出其中的符號的問題。
(4)流程圖
(5)運行結果圖
學習進度條
圖標提示
第六周編程總結