zoukankan      html  css  js  c++  java
  • 习题8-10 输出学生成绩 (20 分)

    本题要求编写程序,根据输入学生的成绩,统计并输出学生的平均成绩、最高成绩和最低成绩。建议使用动态内存分配来实现。

    输入格式:

    输入第一行首先给出一个正整数N,表示学生的个数。接下来一行给出N个学生的成绩,数字间以空格分隔。

    输出格式:

    按照以下格式输出:

    average = 平均成绩
    max = 最高成绩
    min = 最低成绩

    结果均保留两位小数。

    输入样例:

    3
    85 90 95

    输出样例:

    average = 90.00
    max = 95.00
    min = 85.00

    提交:

    #include <stdio.h>
    #include <string.h>
    #include <stdlib.h>
    
    int main() {
    //     int i,j;
    //     char a[5][81];
    //     for (i=0;i<5;i++) scanf("%s",a[i]);//字符串输入
    //     for (i=0;i<4;i++)
    //         for (j=i+1;j<5;j++)
    //             if (strcmp(a[i],a[j]) > 0) {
    //                 char temp[81];
    //                 strcpy(temp,a[i]);
    //                 strcpy(a[i],a[j]);
    //                 strcpy(a[j],temp);
    //             }
    //     printf("After sorted:
    ");
    //     for (i=0; i<5; i++) printf("%s
    ",a[i]); 
    
    //使用动态内存分配
        int n,i;
        int *p;
        float sMax,sMin,sSum = 0;
        float sAvg;
        scanf("%d",&n);
        p = (int *)malloc(sizeof(int) * n);//开启n个int 字节长度
        for (i=0; i<n; i++) {
            scanf("%d",p+i);
            //如果是首个元素,最大值最小值需要赋值
            if (i==0) {
                sMin = *(p+i);//考虑只有1个学生和第一次比较
                sMax = *(p+i);//考虑只有1个学生
            }
            else {
                if (sMax<*(p+i)) sMax = *(p+i);
                if (sMin>*(p+i)) sMin = *(p+i);
            }
            sSum += *(p+i);
        }
        sAvg = sSum / n;
        printf("average = %.2f
    ",sAvg);
        printf("max = %.2f
    ",sMax);
        printf("min = %.2f
    ",sMin);
        free(p);//使用完成,释放内存
        return 0;
    }
  • 相关阅读:
    tomcat启动脚本
    libcrypto.so.1.0.0内容丢失导致sshd无法运行解决方案
    linux最小安装
    linux下文件删除的原理
    Web服务器磁盘满故障深入解析
    入驻博客园,新的开始!!!
    其实我们都可以变得更加优秀!
    我的未来在哪里呢!
    学会选择
    SpringBoot+vue.js如何通过post方式实现导出excel
  • 原文地址:https://www.cnblogs.com/cgy-home/p/15096486.html
Copyright © 2011-2022 走看看