2020年MOOCC语言程序设计精髓第十三周编程题练兵_从键盘输入多(m)个班学生多(n)门课的成绩(n<=10,m<=10-程序员宅基地

技术标签: csp  C语言  c语言  编程语言  

2寻找最高分成绩的学生

题目内容:
下面程序的功能是用动态数组编程输入任意m个班学生(每班n个学生)的某门课的成绩,计算最高分,并指出具有该最高分成绩的学生是第几个班的第几个学生。其中,m和n的值由用户从键盘任意输入(不限定m和n的上限值)。程序的运行结果如下所示:
Input array size m,n:
3,4
Input 34 array:
80 82 63 74
60 81 75 68
87 91 78 92
maxScore = 92, class = 3, number = 4
输入格式:
输入数组大小格式:"%d,%d"
输入数组元素格式:"%d"
输出格式:
输入数组大小的提示信息:“Input array size m,n:\n”
输入数组元素的提示信息:"Input %d
%d array:\n"
输出数据格式:“maxScore = %d, class = %d, number = %d\n”

填空部分用/** _________ **/做了注释
注意程序中有很多printf输出的部分与题目规定不同,注意修改。
#include  <stdio.h>
#include  <stdlib.h>
void InputScore(int *p, int m, int n);
int  FindMax(int *p, int m, int n, int *pRow, int *pCol);             
int main()
{
     
    int  *pScore, m, n, maxScore, row, col;
    printf("Input array size m,n:\n");
    scanf("%d,%d", &m, &n);
    /**_________**/  
    pScore=(int *)calloc(m*n,sizeof(int)); /* 申请动态内存 */
    if (pScore == NULL) 
    {
    
        printf("No enough memory!\n");
        exit(0); 
    }
    InputScore(pScore, m, n);
    /**_________**/
    maxScore = FindMax(pScore,m,n,&row,&col);
    printf("maxScore = %d, class = %d, number = %d\n", maxScore, row+1, col+1);                              
    free(pScore);                                      /* 释放动态内存 */
    return 0;
}
 
/* 函数功能:输入m行n列二维数组的值 */
/**_________**/
void InputScore(int *p, int m, int n) 
{
    
    int i, j;
    printf("Input %d*%d array:\n", m, n);
    for (i=0; i<m; i++)
    {
    
        for (j=0; j<n; j++)
        {
    
            /**_________**/
            scanf("%d", &(p[i*n+j])); 
        }
    }
}
/*  函数功能:计算任意m行n列二维数组中元素的最大值,并指出其所在行列下标值 */
int  FindMax(int *p, int m, int n, int *pRow, int *pCol)    
{
    
    int  i, j, max = p[0];
    /**_________**/
    *pRow=0; 
    /**_________**/
    *pCol=0;                   
     
    for (i=0; i<m; i++)
    {
    
        for (j=0; j<n; j++)
        {
    
            /**_________**/
            if (max<p[i*n+j])        
            {
    
                max = p[i*n+j];
                *pRow = i;       /*记录行下标*/
                *pCol = j;             /*记录列下标*/
            } 
        }  
    }  
    return max;                
}

3程序改错

题目内容:
下面程序的功能是输入m个学生(最多为30人)n门课程(最多为5门)的成绩,然后计算并打印每个学生各门课的总分和平均分。其中,m和n的值由用户从键盘输入。希望的运行结果为:
程序运行结果如下:
How many students?
4
How many courses?
3
Input scores:
60 60 60
70 70 70
80 80 80
90 90 90
Result:
60 60 60 180 60.0
70 70 70 210 70.0
80 80 80 240 80.0
90 90 90 270 90.0
输入格式:

学生人数、课程数、成绩的输入格式都是: “%d”
输出格式:
输入学生人数提示信息:“How many students?\n”
输入课程数提示信息:“How many courses?\n”
输入成绩的提示信息:“Input scores:\n”
输出结果的提示信息: “Result:\n”
每个学生每门课成绩的输出格式: “%4d”
总分和平均分的输出格式: “%5d%6.1f\n”

改错部分用/**    FOUND    **/做了注释
注意程序中有很多printf输出的部分与题目规定不同,注意修改。
#include  <stdio.h>
#define STUD   30      /* 最多可能的学生人数 */
#define COURSE 5       /* 最多可能的考试科目数 */
void  Total(int *pScore, int sum[], float aver[], int m, int n);
void  Print(int *pScore, int sum[], float aver[], int m, int n);
int main()
{
    
    int     i, j, m, n, score[STUD][COURSE], sum[STUD];
    float   aver[STUD];
    printf("How many students?\n");
    scanf("%d", &m);
    printf("How many courses?\n");
    scanf("%d", &n);
    printf("Input scores:\n");
     
    for (i=0; i<m; i++)
    {
    
        for (j=0; j<n; j++)
        {
    
            scanf("%d", &score[i][j]);
        }
    }
     
    Total(*score, sum, aver, m, n);
    Print(*score, sum, aver, m, n);
     return 0;
}
void  Total(int *pScore, int sum[], float aver[], int m, int n)
{
    
    int  i, j;
    for (i=0; i<m; i++)
    {
    
        sum[i] = 0;
        for (j=0; j<n; j++)
        {
    
            /**    FOUND    **/
            sum[i] = sum[i] + pScore[i*COURSE+j];
        }
        aver[i] = (float) sum[i] / n;
    }
}
void  Print(int *pScore, int sum[], float aver[], int m, int n)
{
    
    int  i, j;
    printf("Result:\n");
    for (i=0; i<m; i++)
    {
    
        for (j=0; j<n; j++)
        {
    
            /**    FOUND    **/
            printf("%4d", pScore[i*COURSE+j]);
        }
        printf("%5d%6.1f\n", sum[i], aver[i]);
    }
}

4矩阵转置

题目内容:
下面程序的功能是用二维数组的列指针作为函数实参,计算并输出m×n阶矩阵的转置矩阵。其中,m和n的值由用户从键盘输入。已知m和n的值都不超过10。程序的运行结果如下所示:
Input m, n:
4,5
Input 4*5 matrix:
45 89 90 26 65
21 34 56 77 99
31 25 62 50 46
78 69 84 73 15
The transposed matrix is:
45 21 31 78
89 34 25 69
90 56 62 84
26 77 50 73
65 99 46 15

填空部分用/** _________ **/做了注释
注意程序中有很多printf输出的部分与题目规定不同,注意修改。
#include <stdio.h>
#define M 10
#define N 10
void Transpose(int *a, int *at, int m, int n);
void InputMatrix(int *a, int m, int n);
void PrintMatrix(int *at, int n, int m); 
int main()
{
    
    int s[M][N], st[N][M], m, n;
    printf("Input m, n:\n");
    scanf("%d,%d", &m, &n);
    /** _________ **/
    InputMatrix(*s, m, n);
    /** _________ **/
    Transpose(*s,*st,m,n);
    printf("The transposed matrix is:\n");
    PrintMatrix(*st, n,  m); 
    return 0;
}
/* 函数功能:计算m*n矩阵a的转置矩阵at */
void Transpose(int *a, int *at, int m, int n)   
{
     
    int i, j;
    for (i=0; i<m; i++)
    {
    
        for (j=0; j<n; j++)
        {
    
            /** _________ **/
            at[j*N+i]=a[i*N+j];
        }
    }
}
/* 函数功能:输入m*n矩阵a的值 */
void InputMatrix(int *a, int m, int n)   
{
    
    int i, j;
    printf("Input %d*%d matrix:\n", m, n);
    for (i=0; i<m; i++)
    {
    
        for (j=0; j<n; j++)
        {
    
            /** _________ **/
            scanf("%d", &a[i*N+j]); 
        }
    }
}
/* 函数功能:输出n*m矩阵at的值 */
void PrintMatrix(int *at, int n, int m)   
{
    
    int i, j;
    for (i=0; i<n; i++)
    {
    
        for (j=0; j<m; j++)
        {
    
            /** _________ **/
            printf("%-5d", at[i*N+j]);
        }
        printf("\n");
    }
}

5在升序排序的数组中插入一个元素

题目内容:
用函数编程实现在一个按升序排序的数组中查找x应插入的位置,将x插入数组中,使数组元素仍按升序排列。
提示:插入(Insertion)是数组的基本操作之一。插入法排序算法的关键在于要找到正确的插入位置,然后依次移动插入位置及其后的所有元素,腾出这个位置放入待插入的元素。插入排序的原理如图所示:
程序运行结果示例:
Input array size:
5
Input array:
1 3 5 7 9
Input x:
4
After insert 4:
1 3 4 5 7 9
输入格式:
插入前数组元素个数、数组元素、待插入的元素x的输入格式都是:"%d"
输出格式:
输入插入前数组元素个数提示信息:“Input array size:\n”
输入插入前已按升序排序的数组元素提示信息:“Input array:\n”
输入待插入的元素x提示信息:“Input x:\n”
输出插入x后的数组元素提示信息:“After insert %d:\n”
数组元素输出格式:"%4d"

#include <stdio.h>

int main(){
    
    int i,j,n,*a,x;
    printf("Input array size:\n");
    scanf("%d",&n);
    a=(int *)calloc(n+1,sizeof(int));
    printf("Input array:\n");
    for(i=0;i<n;i++){
    
        scanf("%d",&a[i]);
    }
    printf("Input x:\n");
    scanf("%d",&x);
    for(i=0;i<n;i++){
    
        if(x<a[i])
            break;
    }
    for(j=n-1;j>=i;j--){
    
        a[j+1]=a[j];
    }
    a[i]=x;
    printf("After insert %d:\n",x);
    for(i=0;i<n+1;i++)
        printf("%4d",a[i]);
}

6计算平均数、中位数和众数

题目内容:
在调查数据分析(Survey data analysis)中经常需要计算平均数、中位数和众数。用函数编程计算40个输入数据(是取值1—10之间的任意整数)的平均数(Mean)、中位数(Median)和众数(Mode)。中位数指的是排列在数组中间的数。众数是数组中出现次数最多的那个数(不考虑两个或两个以上的输入数据出现次数相同的情况)。
提示:计算中位数时,首先要调用排序函数对数组按升序进行排序,然后取出排序后数组中间位置的元素answer[n/2] ,就得到了中位数。如果数组元素的个数是偶数,那么中位数就等于数组中间那两个元素的算术平均值。众数就是40个输入数据中出现次数最多的那个数。计算众数时,首先要统计不同取值的输入数据出现的次数,然后找出出现次数最多的那个数据,这个数据就是众数(这里没有考虑两个或者两个以上的输入数据出现次数相同的情况)。
程序运行结果示例:
Input the feedbacks of 40 students:
10 9 10 8 7 6 5 10 9 8
8 9 7 6 10 9 8 8 7 7
6 6 8 8 9 9 10 8 7 7
9 8 7 9 7 6 5 9 8 7
Mean value=7
Median value=8
Mode value=8
输入格式: “%d”
输出格式:
输入数据的提示信息:“Input the feedbacks of 40 students:\n”
平均数输出:“Mean value=%d\n”
中位数输出:“Median value=%d\n”
众数输出: “Mode value=%d\n”

#include <stdio.h>
#define N 40
#define MAX 11

void BubbleSorting(int *a,int n){
    
    int i,j,temp;
    for(i=0;i<n-1;i++){
    
        for(j=n-1;j>i;j--){
    
            if(a[j-1]>a[j]){
    
                temp=a[j];
                a[j]=a[j-1];
                a[j-1]=temp;
            }
        }
    }
}

int main(){
    
    int *a,median,mode=1,sum=0,i;
    int times[MAX]={
    0};
    a=(int *)calloc(N,sizeof(int));
    printf("Input the feedbacks of 40 students:\n");
    for(i=0;i<N;i++){
    
        scanf("%d",&a[i]);
        times[a[i]]++;
        sum+=a[i];
    }
    printf("Mean value=%d\n",sum/N);
    BubbleSorting(a,N);
    if(N%2!=0)
        median=a[N/2];
    else
        median=(a[N/2]+a[N/2-1])/2;
    printf("Median value=%d\n",median);
    for(i=1;i<MAX;i++){
    
        if(times[i]>times[mode])
            mode=i;
    }
    printf("Mode value=%d\n",mode);
}
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_40825479/article/details/105783313

智能推荐

Android阿面试积累,讲的真透彻_android面试如何显示逼格-程序员宅基地

文章浏览阅读378次。基本上稍微大点的公司都会问到,不过我的回答始终如一:我只能看懂C的代码,项目中没有用过JNI,当然这个属于加分项,因为我当时的选择是把我用过熟悉的东西研究地滚瓜烂熟,而不是在自己平时很少接触到的东西上面搞个一知半解。BinderBinder系列,各种AMS,WMS,PWS,常问到的有APP的启动流程,然后两个Activity相互跳转的时候的生命周期,Activity的生命周期。心态不要想着什么都会,那样不现实,比如说我对Binder机制以及热修复,插件化这块儿确实了解地比较浅显,也跟高德,爱奇艺等公_android面试如何显示逼格

One of the configured repositories failed(yum配置存储库失败)-程序员宅基地

文章浏览阅读1w次,点赞5次,收藏26次。One of the configured repositories failed(yum配置存储库失败)_one of the configured repositories failed

JavaWeb_10-框架和项目_javaweb 老项目框架-程序员宅基地

文章浏览阅读169次。自定义框架(ORM框架),持久层框架(mybatis,hibernate)MVC框架(springmvc,struts2)目标:完成自定义springmvc框架项目流程:1.首页加载出最新的前四个商品(按更新时间降序排列)异步请求:按时间排序选到前四个热销商品:在订单明细表中找出前三个卖的最好商品信息(按照productId进行分组,统计数量,按照数量降序排序,取出符合条件的产品id降序排列,再根据id取到数据库信息)分类:暂时不需要parentId进行递归,直接查询出所有分类信息进行显示_javaweb 老项目框架

收藏几款好用的mysql的客户端工具_mysql客户端有哪些-程序员宅基地

文章浏览阅读2.8w次,点赞2次,收藏6次。工欲善其意,必先利其器。好用的工具能成倍提高工作效率,缩短与成功的距离。1. EMSSQL ManagerforMySQL:首先他支持mysql的版本从3.23到6.0都是可以得,也就是说他支持现在所有的版本。他有很友好的界面的非常适合初学者来使用,想找到什么都很方便。2. navicat:也是非常适合初学者使用的工具,他的风格是简单好用,在安装过程中提供7种语言进行选择。..._mysql客户端有哪些

最小二乘法拟合圆 拟合球 公式推导及matlab实现_matlab circlefit函数-程序员宅基地

文章浏览阅读1.1w次,点赞9次,收藏116次。最小二乘法(least squares analysis)是一种数学优化技术,它通过最小化误差的平方和找到一组数据的最佳函数匹配。最小二乘法是用最简的方法求得一些绝对不可知的真值,而令误差平方之和为最小。 最小二乘法通常用于曲线拟合 (least squares fitting) 。这里有拟合圆曲线的公式推导过程和vc实现。多个点拟合圆并给出圆心坐标。matlab 实现:funct..._matlab circlefit函数

详解IP地址-程序员宅基地

文章浏览阅读834次,点赞2次,收藏15次。一、IP地址概念IP地址是一个32位的二进制数,它由网络ID和主机ID两部份组成,用来在网络中唯一的标识的一台计算机。网络ID用来标识计算机所处的网段;主机ID用来标识计算机在网段中的位置。IP地址通常用4组3位十进制数表示,中间用“.”分隔。比如,192.168.0.1。补充(IPv6):前面所讲的32位IP地址称之为IPv4,随着信息技术的发展,IPv4可用IP地址数..._http//192.168.176.15/

随便推点

web网站制作的实例(大学生期末作业)集合_web期末网站设计大作业-程序员宅基地

文章浏览阅读10w+次,点赞140次,收藏1.4k次。一、HTML期末学生结课大作业作品200套web前端期末大作业 HTML+CSS+JavaScript网页设计实例 企业网站制作 [建议收藏]1.HTML期末学生结课大作业~html+css+javascript仿叮当电影在线网站(功能齐全)2.HTML期末学生作业~html+css+javascript仿猫眼电影在线网站(功能齐全)3.HTML期末学生大作业(9套)html+css+javascript仿京东、天猫、服装、各大电商模板(大学毕业设计)4.HTML期末大作业~海贼王中乔巴专题漫画学_web期末网站设计大作业

getvalue参数计数不匹配_那些你不知道的 Python面试题(干货)-程序员宅基地

文章浏览阅读161次。今天带大家感受一波真正的大厂(大公司)的面试真题,我们从现实的热爱Python到现实转化为改变我们生活的幸福基础的金钱是我们的必经阶段,所以关注真正的试题也是我们要做的一个重要的工作。下面我们就开始对这些体进行简单暴力的解答吧!1、一行代码实现1--100之和利用sum()函数求和2、列出5个python标准库os:提供了不少与操作系统相关联的函数sys: 通常用于命令行参数re: 正则..._getvalue和fun

Springer期刊转投_springer nature transfer desk-程序员宅基地

文章浏览阅读3.5k次。写论文投稿至Springer旗下期刊。期刊编辑建议转投,然后查阅了关于转投之后的一些问题,看到了一个链接下的文章,觉得还是解决了一些疑惑的,将链接附在下面,希望能够帮到其他和我遇到一样问题的人期刊主编会“歧视”转投稿件么? Transfer Desk如果 有可能的话,我也会记录部分关于转投的经历。..._springer nature transfer desk

qiankun 微前端_2020年你必须要会的微前端 (实战篇)-程序员宅基地

文章浏览阅读5k次。最近你有没有经常听到一个词,微前端?是不是听上去感觉非常地高大上!然而~微前端其实非常地简单,非常地容易落地,而且也非常不高大上~那么就来一起看看什么是微前端吧:一.为什么需要微前端?这里我们通过3W(what,why,how)的方式来讲解什么是微前端:1.What?什么是微前端?微前端就是将不同的功能按照不同的维度拆分成多个子应用。通过主应用来加载这些子应用。微前端的核心在于拆, 拆完..._qiankun微前端 el-menu

vue+element下拉列表默认值_vue list默认值-程序员宅基地

文章浏览阅读1.7w次,点赞2次,收藏9次。下拉列表中的三项条目deviceSNMPList,默认选中:deviceSNMP:‘1’, deviceSNMPList: [ { key: '0', label: 'v1' }, { key: '1', label: 'v2c' ..._vue list默认值

Chrome下载_谷歌下载官网-程序员宅基地

文章浏览阅读1.4w次,点赞10次,收藏27次。参考:​​​​​​​​​​​​​​​​​​​​​https://zhuanlan.zhihu.com/p/97198043_谷歌下载官网

推荐文章

热门文章

相关标签