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

    前言

    这个作业属于哪个课程 C语言程序设计
    这个作业的要求在哪儿 https://edu.cnblogs.com/campus/zswxy/computer-scienceclass3-2018/homework/2891
    在这个课程的目标 指针
    这个作业在哪些方面帮助我 如何定义指针变量,怎样使用指针变量
    参考文献 教材 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 y;
      y=sqrt(*a)+sqrt(*b);
      return y;
    } 
    

    2.思路
    (1)自定义函数
    (2) y=sqrt(a)+sqrt(b);
    (3)返回y值
    3.问题

    4.正确截图

    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 *a,int *max,int *min,int x);
    int main()
    {
      int n,i,max,min;
      scanf("%d",&n);
      
      int a[n];
      for(i=0;i<n;i++){
        scanf("%d",&a[i]);
      }
      
       max_min(a,&max,&min,n);
       printf("max = %d",max);
       printf("
    ");
       printf("min = %d",min);
       return 0;
       
    }
    
    void max_min(int *a,int *max,int *min,int x)
    {
      int i;
      *max=a[0];
      *min=a[0]; 
      for(i=0;i<x;i++){
            if(*max<a[i])
            {
                *max=a[i];
            }
            if(*min>a[i])
            {
                *min=a[i];
            }  
      }
    }
    

    2.思路
    (1)主函数定义
    (2)数据已数组形式存储
    (3)最大值最小值初始值定义
    (4)循环判断得出最大最小值

    3.问题
    函数定义及格式不清楚
    方法:看书,上网查资料

    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
    作者: 王跃萍
    单位: 东北石油大学
    时间限制: 400 ms
    内存限制: 64 MB

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

    2.思路

    (1)定义函数数据输入
    (2)定义变量
    (3)循环判断得出最大最小下标
    (4)数组数据交换
    (6)数组数据输出

    3.问题
    input函数、output函数的使用,数组数据交换
    解:看书,问同学上网查资料

    4.正确截图

    心得:
    学习是循序渐进的只有一步一个脚印才能扎实的学到知识,而我没做到。所以现在编程能很弱,不能独立完成作业。我也意识到这是一个很严重的问题。下一次作业要有所改变。

  • 相关阅读:
    .NET开发工具
    二维图形的比例变换
    Java对十六进制文件读取
    ??Get Personal SPWeb Object(Mysite Object)获取MOSS个人站点的SPWeb对象
    ?使用SPSiteDataQuery和SPQuery查询不到数据
    moss和exchange 2007的sso
    [解决办法]正在尝试使用已关闭或释放并且不再有效的 SPWeb 对象
    MOSS的用户配置文件及其管理
    Moss要是有两个域用户在用的话.及界面修改 moss2010界面改成2007
    WebForm_PostBackOptions 未定义
  • 原文地址:https://www.cnblogs.com/zh2250881784/p/10657857.html
Copyright © 2011-2022 走看看