#Cprove16~19一维数组初步

NO.1 数组大折腾

(1)创建一个长度为16的整型数组a并初始化,删除数组中所有能被3整除的元素(数组中实际有效使用的元素将不足16),输出删除后数组中的全部元素。
(2)创建一个长度为16的整型数组a并初始化前15个元素,输入一个整数b,将b插入到a[0]位置(原有的数据往后“移动”)。
(3)某人有四张 3分的邮票和三张 5分的邮票,用这些邮票中的一张或若干张可以得到多少种不同的邮资?

代码一
#include<stdio.h>
int main()
{
    int a[16]= {1,2,3,4,5,6,7,8,9,23,54,34,56,78,24,58};
    int i,n,k;

    //方案一
    for(i=0,n=0;i<16;i++)
    {
        if(a[i]%3==0)
            continue;
        a[n]=a[i];
        n++;
    }
     /**<
    //方案二
    for(i=0,n=0;i<16;i++)
        if(a[i]%3)
          a[n++]=a[i];
    */
    for (k=0; k<n ; k++)
        printf("%3d",a[k]);
    return 0;
}
代码二
#include<stdio.h>
int main( )
{
    int a[16]= {1,2,3,4,5,6,7,8,9,10,32,34,54,43,65}; //初始化前15个元素
    int i,b;
    scanf("%d",&b);
    printf("插入b到a[0]后\n");
    for(i=14; i>=0; i--)
        a[i+1]=a[i];
    a[0]=b;
    for(i=0; i<16; i++)
        printf("%d\t",a[i]);
    return 0;
}
代码三
#include<stdio.h>
int main()
{
    int a[28]= {0};
    int i,j,k,s,n=0;
/**<
    //方案一
    for (i=0; i<=4; i++)  //i代表3分邮票张数
        for (j=0; j<=3; j++)  //j代表5分邮票张数
        {
            s=i*3+j*5;
            for (k=0; a[k]; k++)    //循环查重
                if (s==a[k])
                    break;
            if (!a[k]&&s)       //非零s存入数组
            {
                a[k]=s;
                n++;
            }
        }
*/
    //方案二(数组改为a[28],此方案较好理解,建议使用该方案)
    for (i=0; i<=4; i++)  //i代表3分邮票张数
        for (j=0; j<=3; j++)  //j代表5分邮票张数
        {
            s=i*3+j*5;
            a[s]=s;     //重复数据s直接赋值给a[s],就不用循环查重了
        }
    for(i=0; i<28; i++)
        if(a[i])        //去掉零元素
        {
            a[n]=a[i];
            n++;
        }
    printf("%d kind:",n);
    for (k=0; k<n ; k++)
        printf("%3d",a[k]);
    return 0;
}
执行

在这里插入图片描述

NO.2 成绩处理

在数组score中将要存储某小组C程序设计的成绩,请完成下面的处理:
(1)输入小组人数及成绩,要保证成绩在0-100之间;
(2)输出该小组的最高成绩、最低成绩、平均成绩;
(3)输出考得最高成绩和最低成绩的同学的人数;
(4)输出考得最高成绩和最低成绩的同学的学号(设数组下标即学号,可能有相同的成绩)。
(5)(选做)求出所有同学成绩的标准偏差,标准偏差公式为
在这里插入图片描述
其中为样本(即某同学成绩),为均值(前面已经求出),N为样本数目;

代码
#include<stdio.h>
#include<math.h>
int main()
{
    int score[50]; //保存成绩的数组,不会超过50名
    int num,i,max,min,good=0,bad=0;        //小组人数
    float sum=0,ave;
    printf("小组共有多少名同学?");
    scanf("%d", &num);
    max=0;
    min=100;

    printf("请输入学生成绩:\n");
    //输入num名同学的成绩
    for(i=0; i<num; i++)
    {
        printf("输入第 %d 位成绩:",i);
        scanf("%d",&score[i]);
        if(score[i]<0||score[i]>100)
        {
            i--;
            continue;
        }
        max=(score[i]>max)?score[i]:max;
        min=(score[i]<min)?score[i]:min;
        sum+=score[i];
    }
    //求出并输出最高成绩、最低成绩和平均成绩
    ave=sum/num;
    printf("\n最高 %d 分,最低 %d 分,平均 %.2f 分\n",max,min,ave);

    //求出并输出考得最高成绩和最低成绩人数以及学号
    printf("最高成绩学号:");
    for(i=0; i<num; i++)
        if(score[i]==max)
        {
            good++;
            printf("%d\t",i);
        }
    printf("\n最高成绩人数:%d\n",good);
    printf("最低成绩学号:");
    for(i=0; i<num; i++)
    {
        if(score[i]==min)
        {
            bad++;
            printf("%d\t",i);
        }
    }

    printf("\n最低成绩人数:%d\n",bad);

    //求出并输出标准偏差(选做)
    double sqsum=0,std;
    for(i=0;i<num;i++)
        sqsum+=(score[i]-ave)*(score[i]-ave);
    std=sqrt(sqsum/(num-1));
    printf("标准差:%.4lf",std);
    return 0;
}
执行

在这里插入图片描述

NO.3 当年第几天(数组方案)

定义一个函数,其参数为年、月、日的值,返回这一天为该年的第几天。要求在main函数中输入年月日,然后调用这个函数求值,并在main函数中输出结果。

#include<stdio.h>
int days(int y, int m, int d);
int main()
{
    int year, month, day;
    printf("输入年 月 日: ");
    scanf("%d %d %d", &year, &month, &day);
    printf("这是该年的第 %d 天\n", days(year, month, day));
    return 0;
}

int days(int y, int m, int d)
{
    int dd[13]= {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
    //请利用d数组,10行之内,求出并返回y年m月d日是这一年的第几天
    int i,n=d;
    for(i=0; i<m; i++)
        n+=dd[i];
    if((y%100!=0&&y%4==0)||y%400==0)
        n++;
    return n;
}

NO.4 输出52张扑克牌

在这里插入图片描述

#include <stdio.h>
int main( )
{
    char c[4]= {'H','S','D','C'};   //红桃H(HEART),黑桃S(SPADE),方块D(DIAMOND),梅花C(CLUB)
    int v[13]= {1,2,3,4,5,6,7,8,9,10,11,12,13};
    int i,j;
    for(i=0; i<4; i++)
    {
        for(j=0; j<13; j++)
        {
            printf("%c",c[i]);
            if(v[j]==1)
                printf("A");
            else if(v[j]==11)
                printf("J");
            else if(v[j]==12)
                printf("Q");
            else if(v[j]==13)
                printf("K");
            else
                printf("%d",v[j]);
            printf(" ");
        }
        printf("\n");
    }
    return 0;
}

在这里插入图片描述

NO.5 发奖金

(1)过年了,村里要庆祝一下。村长对村里的128个村民说:做一个游戏,让每个人把出生年+月+日得到一个数。例如:1995年11月8日=1995+11+8=2014。然后把这个数报上来。村里有一笔钱要作为游戏的奖金,数额为M元(在程序中可以用常量固定为一个数)。如果有人报上来的数字与M相同,就把这笔钱发给这些人。如果只有一个人得奖,奖金都归这个人。如果有多于一个人得奖,则他们平分这笔钱。现在让我们来写一段程序算算都有哪些人得到了奖金?得到多少?请写出这个程序。
(2)有村民提出村长在幸运数字上做手脚,不公平。修改后的规则是:每人写一个1000以内的数字,谁写的数字与平均值最接近,M元的奖金就由谁拿,有多人与平均值差值相同,则均分。例如,参加的村民有5个人,报的数字分别为98、7、50、980、1,平均值为227(平均值也取成整数就行了),与98最接近,编号为0的村民得奖。

代码一
#include <stdio.h>
#define SIZE 128
#define COM 2018
int main( )
{
    int i,a[SIZE],b[SIZE]={0};
    int year,month,day,count=0;
    double ave;
    for(i=0;i<SIZE;i++)
    {
        printf("第 %d 位报数:",i);
        scanf("%d %d %d",&year,&month,&day);
        a[i]=year+month+day;
        if(a[i]==COM)
        {
            count++;
            b[count-1]=i;
        }
    }
    ave=1.0*COM/count;
    printf("\n得到奖金的村民是:\n");
    for(i=0;i<count;i++)
        printf("%d  ",b[i]);
    printf("\n每位得奖金额为:%.2lf",ave);
    return 0;
}
代码二
#include<stdio.h>
#include<math.h>
#define SIZE 12
#define money 10000
int main( )
{
    int i,n,a[SIZE];
    int sum=0,ave,every,min=1000,b[SIZE]={0};
     //a[SIZE]录入村民报数数据,求和,之后求平均值
    for(i=0;i<SIZE;i++)        
    {
        printf("第 %d 位报数:",i);
        scanf("%d",&a[i]);
        if(a[i]>1000)
        {
            i--;
            continue;
        }
        sum+=a[i];
    }
    ave=sum/SIZE;
    //b[SIZE]录入村民报数与平均值的差值绝对值,将最小绝对值找到
    for(i=0;i<SIZE;i++)    
    {
        b[i]=fabs(a[i]-ave);
        min=(b[i]<min)?b[i]:min;
    }
    //把最小绝对值对应的村民编号(下标)录入b[n],报数录入a[n];n为最小绝对值重复个数
    for(i=0,n=0;i<SIZE;i++) 
        if(b[i]==min)
        {
            a[n]=a[i];
            b[n++]=i;
        }
    every=money/n;
     //把 n 个得奖人数据输出
    for(i=0;i<n;i++)   
    printf("\n得奖人:%d号\t报数:%d\n",b[i],a[i]);
    printf("每人奖金:%d 元\n",every);
    return 0;
}
执行代码二

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值