第六周作业

本文解析了几道C语言程序设计中的指针练习题,包括求两数平方根之和、找出数组的最大最小值及交换数组首尾元素等题目,并讨论了指针的用途及其在内存中的占用情况。
这个作业属于哪个课程c语言程序设计
这个作业要求在哪里https://edu.cnblogs.com/campus/zswxy/software-engineering-class2-2018/homework/2888
我在这个课程的目标是指针
这个作业在哪个具体方面帮助我实现目标加强了对指针的了解
参考文献http://c.harson.co/
1.基础作业 函数题:求两数平方根之和

函数fun的功能是:求两数平方根之和,作为函数值返回。例如:输入12和20,输出结果是:y = 7.936238。

函数接口定义::

double fun (double *a, double *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 (double *a, double *b)
{
  double y;
  y=pow(*a,0.5)+pow(*b,0.5);
  return y;
}

2).设计思路

1580838-20190405184425227-725335428.png

3).问题和解决方案

4).运行结果

1580838-20190405192541867-1574330563.jpg

是n个数。

输出格式:
输出最大值和最小值。

输入样例:
在这里给出一组输入。例如:

5
8 9 12 0 3

输出样例:
在这里给出相应的输出。例如:

max = 12
min = 0

1).实验代码

#include<stdio.h> 
void max_min(int a[], int n, int *pmax, int *pmin);
int main()
{
    int i,n,max,min;
    scanf("%d",&n);
    int a[n];
    for(i=0;i<n;i++){
        scanf("%d",&a[i]);
    }
       max_min(a,n,&max,&min);  //把max和min地址赋给指针变量
       printf("max = %d\nmin = %d",max,min);
  
       return 0;
}
void max_min(int a[],int n, int *pmax, int *pmin)
{
      int max,min,k,i,t;
      for(k=0;k<n-1;k++){   //选择排序
        max=k;
        for(i=k+1;i<n;i++)
        if(a[i]>a[max])
        max=i;
        t=a[max];
        a[max]=a[k];
        a[k]=t;
    }
       *pmax=a[0]; //第一个数最大
       *pmin=a[n-1];  //倒数第二个数最小
}

2).设计思路

1580838-20190405184544111-1767313258.png

3).问题和解决方案

3. 基础作业 思考题

1.为什么要使用指针?它有什么用?

在数据传递时,如果数据块较大(比如说数据缓冲区或比较大的结构),这时就可以使用指针传递地址而不是实际数据,即提高传输速度,又节省大量内存。为动态数据结构(如二叉树、链表)提供支持。在函数调用中使用指针还可以返回多个值。

2.指针变量在内存中暂用多大的空间?它的大小由什么决定?

32位处理器上32位操作系统的32位编译器,指针大小4字节。32位处理器上32位操作系统的16位编译器,指针大小2字节。 32位处理器上16位操作系统的16位指针大小2字节。16位处理器上16位操作系统的16位编译器,指针大小2字节。

4.预习作业 最小数放前最大数放后

为一维数组输入10个整数;将其中最小的数与第一个数对换,将最大的数与最后一个数对换;输出数组元素。

函数接口定义:

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

裁判测试程序样例:

#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)
{
    int i;
    for(i=0;i<n;i++)
    {
        scanf("%d",&arr[i]);
    }
}
void max_min(int *arr,int n)
{
    int i,t, max,min,a=0,b=0;
    min = max = arr[0];
    for(i=0;i<10;i++)
    {
        if(max <= arr[i])  
        {
            max = arr[i]; 
            a = i;  
        }
        if(min >= arr[i]) 
        {
            min = arr[i];
            b = i; 
        }
    }
    t = arr[9];
    arr[9] = arr[a];
    arr[a] = t;
    t = arr[0];
    arr[0] = arr[b];
    arr[b] = t;
}
void output(int *arr,int n)
{
    int i;
    for(i=0;i<n;i++)
    {
        printf("%3d",arr[i]);
    }
}

2).设计思路

1580838-20190405184804268-1698787217.png

3).问题和解决方案

做题中忘了给最值初始化导致答案错误,解决方案,最值初始化。

4).运行结果

1580838-20190405192613607-1567337646.jpg

| :----: | :-----: | :----------:|:---------:|
| 4.1-4.7 | 4小时 | 110 | 指针 | 暂无 |

转载于:https://www.cnblogs.com/ll-dl2018/p/10659474.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值