zoukankan      html  css  js  c++  java
  • 第六周作业

    这个作业属于那个课程 C语言程序设计II
    这个作业要求在哪里 https://edu.cnblogs.com/campus/zswxy/software-engineering-class1-2018/homework/2825
    我在这个课程的目标是 能够准确的写出代码
    这个作业在那个具体方面帮助我实现目标 指针
    参考文献 C语言课本和百度

    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 );
     y=fun(&a, &b); printf ("y=%.2f
    ", y );
    return 0;
    }
    
    
    /* 请在这里填写答案 */
    

    输入样例:

    12 20
    

    输出样例:

    y=7.94
    

    1、实验代码:

    double fun (double *a,double *b)
    {
      double t,n,y;
      t=sqrt(*a);
      n=sqrt(*b);
      y=t+n;
      return y;
    }
    

    2、流程图:

    3、运行结果截图:

    7-1 利用指针返回多个函数值 (30 分)

    读入n个整数,调用max_min()函数求这n个数中的最大值和最小值。

    输入格式:
    输入有两行: 第一行是n值; 第二行是n个数。

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

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

    5
    8 9 12 0 3
    

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

    max = 12
    min = 0
    

    1、实验代码:

    #include<stdio.h>
    void max_min(int m[],int d,int *pa,int *pb); 
    int main(void)
    {
    	int a=0,b=0,i=0,d=0,n;
    	int m[1000];
    	scanf("%d",&n);
    	for(i=0;i<n;i++){
    		scanf("%d",&m[i]);
    		d++;
    	}
    	max_min(m,d,&a,&b);
    	printf("max = %d
    ",a);
    	printf("min = %d",b);
    	
    	return 0;
    }
    void max_min(int m[],int d,int *pa,int *pb)
    {
    	int j=0,i;
    
    	for(i=0;i<d;i++){
    		if(m[i]>=m[j]){
    			j=i;
    			*pa=m[i];
    		}
    	}
    	j=0;
    	for(i=0;i<d;i++){
    		if(m[i]<=m[j]){
    			j=i;
    			*pb=m[i];
    		}
    	}
    }
    

    2、流程图:

    3、调试过程遇到的问题:

    问题1:

    解决办法:上网查了一下发现必须要在调用函数里面定义一下那个输入的数组不然解释的时候无法直接用。

    4、运行结果截图:

    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 *air, int n)
    {
      int i=0;
      for(i=0;i<n;i++){
        scanf("%d",air+i);
      }
    }
    void max_min(int *air,int n)
    {
      int i=0,b=0,c=0,d=0;
      for(i=1;i<n;i++){
        if(*(air+c)>*(air+i)){
            c=i;
    	}
      }
      d=*(air+c),*(air+c)=*air,*air=d;
      c=0;
      for(i=1;i<n;i++){
        if(*(air+i)>*(air+c)){
        	c=i;
    	}
      }
      b=*(air+c),*(air+c)=*(air+n-1),*(air+n-1)=b;
    }
    void output(int *air, int n)
    {
      int i;
      for(i=0;i<n;i++){
         printf("%3d",*(air+i));
      }
    }
    

    2、流程图:

    3、调试过程遇到的问题:

    问题1:

    解决办法:发现互换的时候顺序搞混乱了所以才造成了有两个1和两个12。

    4、运行结果截图:

    思考题:(分值等同于编程题)

    1.为什么要使用指针?它有什么用?
    配合调用函数来进行变量之间的互换。

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

    它跟它的类型有关,也可能跟电脑有关。

    学习进度条:

    周/日期 这周所花的时间 代码行 学到的知识点简介 目前比较困惑的问题
    3/11~3/16 10小时 46行 可以同时利用一维数组和二维数组来解题,以及二维数组的使用。 二维数组的二组循环比较迷惑
    3/18~3/22 8小时 110 行 冒泡排序和选择排序有相似之处,冒泡找最大值或找最小值是重复比较的,而选择一步到位。 冒泡排序按书上哪种方法把最后一个if判断条件改成小于为什么不能按大到小的顺序输出
    3/25~3/29 11小时 69行 strcpy可以用来替换字符串 如何更快的输入字符以及能不能一个一个字符串的输入
    4/1~4/5 8小时 74行 用指针来进行互换 指针和数组的关联还不太熟悉
  • 相关阅读:
    VBA基础四:数据库链接(WPS2019)
    VBA基础三:循环(DO...LOOP,)
    随机多人红包
    概率抽奖
    七步轻松实现大数据库表的数据转储
    SQL Server中的行列倒置技巧
    把对应表的字段跨表赋值
    sql内日期格式化输出
    事务的用法
    女孩,你为什么不沉住气奋斗
  • 原文地址:https://www.cnblogs.com/xht8657/p/10659139.html
Copyright © 2011-2022 走看看