PAT (Basic Level) Practise-1012. 数字分类 (20)
2016-09-12 22:38
519 查看
题目链接:
https://www.patest.cn/contests/pat-b-practise/1012
题目:
给定一系列正整数,请按要求对数字进行分类,并输出以下5个数字:
A1 = 能被5整除的数字中所有偶数的和;
A2 = 将被5除后余1的数字按给出顺序进行交错求和,即计算n1-n2+n3-n4...;
A3 = 被5除后余2的数字的个数;
A4 = 被5除后余3的数字的平均数,精确到小数点后1位;
A5 = 被5除后余4的数字中最大数字。
输入格式:
每个输入包含1个测试用例。每个测试用例先给出一个不超过1000的正整数N,随后给出N个不超过1000的待分类的正整数。数字间以空格分隔。
输出格式:
对给定的N个正整数,按题目要求计算A1~A5并在一行中顺序输出。数字间以空格分隔,但行末不得有多余空格。
若其中某一类数字不存在,则在相应位置输出“N”。
输入样例1:
输出样例1:
输入样例2:
输出样例2:
欢迎交流:
#include<stdio.h>
int main(){
int a, b, c, d, e, N;//分别表示A1 A2 A3 A4 A5 N
int num_b, num_d;
double ave = 0;
bool flag0,flag1, flag2, flag3, flag4;//标志某一类数字是否存在
flag0=flag1 = flag2 = flag3 = flag4 = false;
a = b = c = d = e =0;
N = num_b = num_d = 0;
scanf("%d", &N);
while (N--){
int x = 0;
scanf("%d", &x);
switch (x % 5){
case 0:
if (x % 2 == 0) {
flag0 = true;
a += x;
}
break;
case 1:
flag1= true;
num_b++;
if (num_b % 2 == 1)b += x;
if (num_b % 2 == 0) b -= x;
break;
case 2:
flag2 = true;
c++;
break;
case 3:
flag3 = true;
num_d++;
d += x;
ave = (double)d / (double)num_d;//不能用(double)(d/num_d),因为(d/num_d)结果为x.0000...,而(double)(d/num_d)就为x
break;
case 4:
flag4 = true;
if (x > e) e = x;
break;
default:
printf("error!");
break;
}
}
if (flag0==false) printf("N ");
else printf("%d ", a);
if (flag1==false) printf("N ");
else printf("%d ", b);
if (flag2==false) printf("N ");
else printf("%d ", c);
if (flag3==false) printf("N ");
else printf("%.1lf ", ave);
if (flag4 == false) printf("N");
else printf("%d", e);
return 0;
}
原错误代码:
/*
原错误代码:将a,b,c,d,e初始化为N,在case语句中替代flag语句
*/
#include<stdio.h>
int main(){
int a, b, c, d, e,N;//分别表示A1 A2 A3 A4 A5 N
int num_b, num_d;
double ave=0;
a = b = c = d = e = 'N';//实际上a-e均被初始化为78
N =num_b=num_d= 0;
scanf("%d", &N);
while (N--){
int x=0;
scanf("%d", &x);
switch (x % 5){
case 0:
if (x % 2 == 0) {
if (a == 'N') a = 0;
a += x;
}
break;
case 1:
if (b == 'N') b = 0;
num_b++;
if (num_b % 2 == 1)b += x;
if (num_b % 2 == 0) b -= x;
break;
case 2:
if (c == 'N') c = 0;
c++;
break;
case 3:
if (d == 'N') d = 0;
num_d++;
d += x;
ave = (double)d /(double) num_d;//不能用(double)(d/num_d),因为(d/num_d)结果为x.0000...,而(double)(d/num_d)就为x
break;
case 4:
if (e == 'N') e = 0;
if (x > e) e = x;
break;
default:
printf("error!");
break;
}
}
if (a == 'N')printf("N ");
else printf("%d ",a);
if (b == 'N')printf("N ");
else printf("%d ", b);
if (c == 'N')printf("N ");
else printf("%d ",c);
if (d == 'N')printf("N ");
else printf("%.1lf ", ave);
if (e == 'N')printf("N");
else printf("%d", e);
return 0;
}
https://www.patest.cn/contests/pat-b-practise/1012
题目:
1012. 数字分类 (20)
给定一系列正整数,请按要求对数字进行分类,并输出以下5个数字:A1 = 能被5整除的数字中所有偶数的和;
A2 = 将被5除后余1的数字按给出顺序进行交错求和,即计算n1-n2+n3-n4...;
A3 = 被5除后余2的数字的个数;
A4 = 被5除后余3的数字的平均数,精确到小数点后1位;
A5 = 被5除后余4的数字中最大数字。
输入格式:
每个输入包含1个测试用例。每个测试用例先给出一个不超过1000的正整数N,随后给出N个不超过1000的待分类的正整数。数字间以空格分隔。
输出格式:
对给定的N个正整数,按题目要求计算A1~A5并在一行中顺序输出。数字间以空格分隔,但行末不得有多余空格。
若其中某一类数字不存在,则在相应位置输出“N”。
输入样例1:
13 1 2 3 4 5 6 7 8 9 10 20 16 18
输出样例1:
30 11 2 9.7 9
输入样例2:
8 1 2 4 5 6 7 9 16
输出样例2:
N 11 2 N 9
欢迎交流:
#include<stdio.h>
int main(){
int a, b, c, d, e, N;//分别表示A1 A2 A3 A4 A5 N
int num_b, num_d;
double ave = 0;
bool flag0,flag1, flag2, flag3, flag4;//标志某一类数字是否存在
flag0=flag1 = flag2 = flag3 = flag4 = false;
a = b = c = d = e =0;
N = num_b = num_d = 0;
scanf("%d", &N);
while (N--){
int x = 0;
scanf("%d", &x);
switch (x % 5){
case 0:
if (x % 2 == 0) {
flag0 = true;
a += x;
}
break;
case 1:
flag1= true;
num_b++;
if (num_b % 2 == 1)b += x;
if (num_b % 2 == 0) b -= x;
break;
case 2:
flag2 = true;
c++;
break;
case 3:
flag3 = true;
num_d++;
d += x;
ave = (double)d / (double)num_d;//不能用(double)(d/num_d),因为(d/num_d)结果为x.0000...,而(double)(d/num_d)就为x
break;
case 4:
flag4 = true;
if (x > e) e = x;
break;
default:
printf("error!");
break;
}
}
if (flag0==false) printf("N ");
else printf("%d ", a);
if (flag1==false) printf("N ");
else printf("%d ", b);
if (flag2==false) printf("N ");
else printf("%d ", c);
if (flag3==false) printf("N ");
else printf("%.1lf ", ave);
if (flag4 == false) printf("N");
else printf("%d", e);
return 0;
}
原错误代码:
/*
原错误代码:将a,b,c,d,e初始化为N,在case语句中替代flag语句
*/
#include<stdio.h>
int main(){
int a, b, c, d, e,N;//分别表示A1 A2 A3 A4 A5 N
int num_b, num_d;
double ave=0;
a = b = c = d = e = 'N';//实际上a-e均被初始化为78
N =num_b=num_d= 0;
scanf("%d", &N);
while (N--){
int x=0;
scanf("%d", &x);
switch (x % 5){
case 0:
if (x % 2 == 0) {
if (a == 'N') a = 0;
a += x;
}
break;
case 1:
if (b == 'N') b = 0;
num_b++;
if (num_b % 2 == 1)b += x;
if (num_b % 2 == 0) b -= x;
break;
case 2:
if (c == 'N') c = 0;
c++;
break;
case 3:
if (d == 'N') d = 0;
num_d++;
d += x;
ave = (double)d /(double) num_d;//不能用(double)(d/num_d),因为(d/num_d)结果为x.0000...,而(double)(d/num_d)就为x
break;
case 4:
if (e == 'N') e = 0;
if (x > e) e = x;
break;
default:
printf("error!");
break;
}
}
if (a == 'N')printf("N ");
else printf("%d ",a);
if (b == 'N')printf("N ");
else printf("%d ", b);
if (c == 'N')printf("N ");
else printf("%d ",c);
if (d == 'N')printf("N ");
else printf("%.1lf ", ave);
if (e == 'N')printf("N");
else printf("%d", e);
return 0;
}
相关文章推荐
- HDU 5875 Function(预处理)
- 计算机视觉牛人博客和代码汇总(全)
- uC/OS_Ⅱ笔记
- 双重循环打印十位比个位少的数字
- extern与头文件(*.h)的区别和联系
- extern与头文件(*.h)的区别和联系
- 第八章在ARM7上移植uc/os-2
- 人机猜拳
- Android的布局(二)
- BZOJ4034 T2
- queue与topic的技术特点对比
- HDU 1698 Just a Hook (线段树:成段替换)
- 配置Nginx网站https访问、http共存访问、http强制跳转到https
- 配置Nginx网站https访问、http共存访问
- 关于strcpy和memcpy
- C语言生成服从均匀分布, 瑞利分布, 莱斯分布, 高斯分布的随机数
- 服务设计模式一:Web服务概述
- Baxter学习笔记2-Kinect摄像头驱动安装篇
- React实战-深入源码了解Redux用法之Reducers
- 点按触发水波纹效果