第六週做業

做業頭c++

6-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;
}測試

實驗截圖spa

 

 

實驗流程圖3d

 

實驗總結:這個題目比較簡單和編程隊友討論了一下就得出答案了指針

7-1 利用指針返回多個函數值code

讀入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個整數;將其中最小的數與第一個數對換,將最大的數與最後一個數對換;輸出數組元素。。

函數接口定義:

void input(int *arr,int n);
void max_min(int *arr,int n);
void output(int *arr,int n);

三個函數中的 arrn 都是用戶傳入的參數。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]);
    }
}
實驗截圖
 

 

實驗感想:這題不是很會經過看他人博客上網收尋後得出
學習進度表
 
相關文章
相關標籤/搜索