第6周編程總結
本次作業所屬課程 | C語言程序設計|| | |
本次作業要求 | https://pintia.cn/problem-sets?tab=1 | |
我在這個課程的目標是 | 學會使用指針 | |
本次學習在哪些具體方面幫組我實現目標 | 書本和練習題中 | |
參考文獻 |
|
函數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
實驗代碼
double fun (double *a, double *b)
{
double sum;
sum=sqrt(*a)+sqrt(*b);
return sum;
}
錯誤截圖
正確截圖
實驗流程圖
編程感想:很多地方還是和編程結對隊友討論才知道的
7-1 利用指針返回多個函數值 (30 分)
讀入n個整數,調用max_min()函數求這n個數中的最大值和最小值。
輸入格式:
輸入有兩行: 第一行是n值; 第二行是n個數。
輸出格式:
輸出最大值和最小值。
輸入樣例:
在這裏給出一組輸入。例如:
5
8 9 12 0 3
輸出樣例:
在這裏給出相應的輸出。例如:
max = 12
min = 0
實驗代碼
#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];
}
}
正確截圖
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
實驗代碼
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]);
}
}
正確截圖
感想:一個人有很多地方還是不懂,需要編程隊友的幫助,這種結對編程的方式對我的幫助很大
學習進度表
第6周編程總結