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;
}