大一C语言程序设计练习题二
A - 平方和与立方和
Description
给定一段连续的整数,求出他们中所有偶数的平方和以及所有奇数的立方和。
Input
输入数据包含多组测试实例,每组测试实例包含一行,由两个整数m和n组成。
Output
对于每组输入数据,输出一行,应包括两个整数x和y,分别表示该段连续的整数中所有偶数的平方和以及所有奇数的立方和。
你可以认为32位整数足以保存结果。
Sample Input
1 3
2 5
Sample Output
4 28
20 152
代码如下(示例):
#include <stdio.h>
void main()
{
int a,b,i,s1,s2,t;
while(~scanf("%d%d",&a,&b))
{
s1=0,s2=0;
if(a<b)
;
else
t=a,a=b,b=t;
for(i=a;i<=b;i++)
{
if(i%2==0)
s1+=i*i;
else
s2+=i*i*i;
}
printf("%d %d\n",s1,s2);
}
}
B - 成绩转换
Description
输入一个百分制的成绩t,将其转换成对应的等级,具体转换规则如下:
90~100为A;
80~89为B;
70~79为C;
60~69为D;
0~59为E;
Input
输入数据有多组,每组占一行,由一个整数组成。
Output
对于每组输入数据,输出一行。如果输入数据不在0~100范围内,请输出一行:“Score is error!”。
Sample Input
56
67
100
123
Sample Output
E
D
A
Score is error!
代码如下(示例):
#include <stdio.h>
void main()
{
int t;
while(~scanf("%d",&t))
{
if(t>=0&&t<=59)
printf("E\n");
else if(t>59&&t<=100)
{
switch(t/10)
{
case 6:printf("D\n");
break;
case 7:printf("C\n");
break;
case 8:printf("B\n");
break;
case 9:printf("A\n");
break;
case 10:printf("A\n");
break;
}
}
else
printf("Score is error!\n");
}
}
C - 第几天?
Description
给定一个日期,输出这个日期是该年的第几天。
Input
输入数据有多组,每组占一行,数据格式为YYYY/MM/DD组成,具体参见sample input ,另外,可以向你确保所有的输入数据是合法的。
Output
对于每组输入数据,输出一行,表示该日期是该年的第几天。
Sample Input
1985/1/20
2006/3/12
Sample Output
20
71
代码如下(示例):
#include<stdio.h>
int main()
{
int year, month, day, i, sum = 0;
int a[12] = { 31,29,31,30,31,30,31,31,30,31,30,31 };
int b[12] = { 31,28,31,30,31,30,31,31,30,31,30,31 };
while (scanf("%d/%d/%d", &year, &month, &day) != EOF)
{
if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0)
{
for (i = 0; i < month - 1; i++)
{
sum += a[i];
}
sum = sum + day;
printf("%d\n", sum);
}
else
{
for (i = 0; i < month - 1; i++)
{
sum += b[i];
}
sum += day;
printf("%d\n", sum);
}
sum = 0;
}
return 0;
}
D - 水仙花数
Description
春天是鲜花的季节,水仙花就是其中最迷人的代表,数学上有个水仙花数,他是这样定义的:
“水仙花数”是指一个三位数,它的各位数字的立方和等于其本身,比如:153=13+53+3^3。
现在要求输出所有在m和n范围内的水仙花数。
Input
输入数据有多组,每组占一行,包括两个整数m和n(100<=m<=n<=999)。
Output
对于每个测试实例,要求输出所有在给定范围内的水仙花数,就是说,输出的水仙花数必须大于等于m,并且小于等于n,如果有多个,则要求从小到大排列在一行内输出,之间用一个空格隔开;
如果给定的范围内不存在水仙花数,则输出no;
每个测试实例的输出占一行。
Sample Input
100 120
300 380
Sample Output
no
370 371
代码如下(示例):
# include<stdio.h>
# include<math.h>
int main()
{
int m,n,i,sum,a,b,c,x=0;
int flag;
while((scanf("%d%d",&m,&n)!=EOF))
{
x=0;
for(i=m;i<=n;i++)
{
a=i/100%10;
b=i/10%10;
c=i%10;
sum=pow(a,3)+pow(b,3)+pow(c,3);
if(i==sum)
{
if(x==0) printf("%d",i);
else printf(" %d",i);
x++;
}
}
if(x==0)
printf("no");
putchar(10);
}
return 0;
}
E - 计算两点间的距离
Description
输入两点坐标(X1,Y1),(X2,Y2),计算并输出两点间的距离。
Input
输入数据有多组,每组占一行,由4个实数组成,分别表示x1,y1,x2,y2,数据之间用空格隔开。
Output
对于每组输入数据,输出一行,结果保留两位小数。
Sample Input
0 0 0 1
0 1 1 0
Sample Output
1.00
1.41
代码如下(示例):
# include<stdio.h>
# include<math.h>
int main()
{
double x1,y1,x2,y2,d;
while(scanf("%lf %lf %lf %lf",&x1,&y1,&x2,&y2)!=EOF)
{
d=sqrt(pow(x2-x1,2)+pow(y2-y1,2));
printf("%0.2lf\n",d);
}
return 0;
}