查询出编号长度大于4的code_中国大学MOOC-翁恺-C语言程序设计习题集-解答汇总...

这是一个关于C语言程序设计的习题集,包含了多个PAT(PProgramming Ability Test)题目,涉及整数运算、厘米换算英尺英寸、时间计算、逆序三位数、BCD解密、超速判断等。每个题目都给出了详细的时间和内存限制,以及相应的输入输出格式,并附带了样例输入和输出。解题代码用C语言编写,旨在锻炼编程能力。
摘要由CSDN通过智能技术生成

中国大学MOOC-翁恺-C语言程序设计习题集

PAT 习题集c++

02-0. 整数四则运算(10)

时间限制

400 ms

内存限制

65536 kB

代码长度限制

8000 B

判题程序

Standard

做者

乔林(清华大学)

本题要求编写程序,计算2个正整数的和、差、积、商并输出。题目保证输入和输出所有在整型范围内。git

输入格式:oop

输入在一行中给出2个正整数A和B。测试

输出格式:ui

在4行中按照格式“A 运算符 B = 结果”顺序输出和、差、积、商。spa

输入样例:

3 2

输出样例:

3 + 2 = 5

3 - 2 = 1

3 * 2 = 6

3 / 2 = 1

#include

int main()

{

int A;

int B;

int X, Y, Z, W;

scanf("%d %d", &A, &B);

X = A + B;

Y = A - B;

Z = A * B;

W = A / B;

printf("%d + %d = %d\n" ,A, B, X);

printf("%d - %d = %d\n", A, B, Y);

printf("%d * %d = %d\n", A, B, Z);

printf("%d / %d = %d\n", A, B, W);

return 0;

}

02-1. 厘米换算英尺英寸(15)

时间限制

400 ms

内存限制

65536 kB

代码长度限制

8000 B

判题程序

Standard

做者

翁恺(浙江大学)

若是已知英制长度的英尺foot和英寸inch的值,那么对应的米是(foot+inch/12)*0.3048。如今,若是用户输入的是厘米数,那么对应英制长度的英尺和英寸是多少呢?别忘了1英尺等于12英寸。.net

输入格式:设计

输入在一行中给出1个正整数,单位是厘米。code

输出格式:blog

在一行中输出这个厘米数对应英制长度的英尺和英寸的整数值,中间用空格分开。

输入样例:

170

输出样例:

5 6

#include

int main()

{

int cm;

scanf("%d", &cm);

int foot = cm / 30.48;

int inch = (cm/30.48 - foot) * 12;

printf("%d %d", foot, inch);

return 0;

}

02-2. 而后是几点(15)

时间限制

400 ms

内存限制

65536 kB

代码长度限制

8000 B

判题程序

Standard

做者

翁恺(浙江大学)

有时候人们用四位数字表示一个时间,好比1106表示11点零6分。如今,你的程序要根据起始时间和流逝的时间计算出终止时间。读入两个数字,第一个数字以这样的四位数字表示当前时间,第二个数字表示分钟数,计算当前时间通过那么多分钟后是几点,结果也表示为四位数字。当小时为个位数时,没有前导的零,即5点30分表示为530。注意,第二个数字表示的分钟数可能超过60,也多是负数。

输入格式:

输入在一行中给出2个整数,分别是四位数字表示的起始时间、以及流逝的分钟数,其间以空格分隔。注意:在起始时间中,当小时为个位数时,没有前导的零,即5点30分表示为530;流逝的分钟数可能超过60,也多是负数。

输出格式:

输出四位数字表示的终止时间。题目保证起始时间和终止时间在同一天内。

输入样例:

1120 110

输出样例:

1310

#include

int main()

{

int i, j, x = 0, y, z;

scanf("%d%d", &i, &j);

if(i >= 1000)

{

x = i / 1000;

y = (i % 1000) / 100;

z = (i %1000) %100;

}

else

{

y = i / 100;

z = i % 100;

}

int s = (10*x + y) * 60 + z;

int n = s + j;

i = n / 60 *100 + (n - ((n / 60 )* 60));

printf("%d", i);

return 0;

}

02-3. 逆序的三位数(10)

时间限制

400 ms

内存限制

65536 kB

代码长度限制

8000 B

判题程序

Standard

做者

翁恺(浙江大学)

程序每次读入一个正3位数,而后输出按位逆序的数字。注意:当输入的数字含有结尾的0时,输出不该带有前导的0。好比输入700,输出应该是7。

输入格式:

每一个测试是一个3位的正整数。

输出格式:

输出按位逆序的数。

输入样例:

123

输出样例:

321

#include

int main()

{

int i;

scanf("%d", &i);

int a = i % 100 %10;

int b = i / 100;

int c = i %100 / 10;

i = a*100 + b + c*10;

printf("%d", i);

return 0;

}

02-4. BCD解密(10)

时间限制

400 ms

内存限制

65536 kB

代码长度限制

8000 B

判题程序

Standard

做者

翁恺(浙江大学)

BCD数是用一个字节来表达两位十进制的数,每四个比特表示一位。因此若是一个BCD数的十六进制是0x12,它表达的就是十进制的12。可是小明没学过BCD,把全部的BCD数都看成二进制数转换成十进制输出了。因而BCD的0x12被输出成了十进制的18了!

如今,你的程序要读入这个错误的十进制数,而后输出正确的十进制数。提示:你能够把18转换回0x12,而后再转换回12。

输入格式:

输入在一行中给出一个[0, 153]范围内的正整数,保证能转换回有效的BCD数,也就是说这个整数转换成十六进制时不会出现A-F的数字。

输出格式:

输出对应的十进制数。

输入样例:

18

输出样例:

12

#include

int main()

{

int i;

scanf("%d", &i);

int t = i % 16 + i / 16 * 10;

printf("%d", t);

return 0;

}

03-0. 超速判断(10)

时间限制

400 ms

内存限制

65536 kB

代码长度限制

8000 B

判题程序

Standard

做者

杨起帆(浙江大学城市学院)

模拟交通警察的雷达测速仪。输入汽车速度,若是速度超出60 mph,则显示“Speeding”,不然显示“OK”。

输入格式:

输入在一行中给出1个不超过500的非负整数,即雷达测到的车速。

输出格式:

在一行中输出测速仪显示结果,格式为:“Speed: V - S”,其中V是车速,S或者是Speeding、或者是OK。

输入样例1:

40

输出样例1:

Speed: 40 - OK

输入样例2:

75

输出样例2:

Speed: 75 - Speeding

#include

int main()

{

int i;

scanf("%d", &i);

if(i <= 60)

printf("Speed: %d - OK", i);

else

printf("Speed: %d - Speeding", i);

return 0;

}

03-1. 三天打鱼两天晒网(15)

时间限制

400 ms

内存限制

65536 kB

代码长度限制

8000 B

判题程序

Standard

中国有句俗语叫“三天打鱼两天晒网”。假设某人从某天起,开始“三天打鱼两天晒网”,问这我的在之后的第N天中是“打鱼”仍是“晒网”?

输入格式:

输入在一行中给出1个不超过1000的正整数N。

输出格式:

在一行中输出此人在第N天中是“Fishing”(即“打鱼”)仍是“Drying”(即“晒网”),而且输出“in day N”。

输入样例1:

103

输出样例1:

Fishing in day 103

输入样例2:

34

输出样例2:

Drying in day 34

#include

int main()

{

int i;

scanf("%d", &i);

if(i%5 <= 3 && i%5 != 0)

printf("Fishing in day %d", i);

else

printf("Drying in day %d", i);

return 0;

}

03-2. 用天平找小球(10)

时间限制

400 ms

内存限制

65536 kB

代码长度限制

8000 B

判题程序

Standard

三个球A、B、C,大小形状相同且其中有一个球与其余球重量不一样。要求找出这个不同的球。

输入格式:

输入在一行中给出3个正整数,顺序对应球A、B、C的重量。

输出格式:

在一行中输出惟一的那个不同的球。

输入样例:

1 1 2

输出样例:

C

# include

int main()

{

int A, B, C;

scanf("%d%d%d",&A, &B, &C);

if(A != B && B ==C)

printf("A");

else if(B != A && A == C)

printf("B");

else if(C != A && A == B)

printf("C");

return 0;

}

03-3. 12-24小时制(15)

时间限制

400 ms

内存限制

65536 kB

代码长度限制

8000 B

判题程序

Standard

做者

翁恺(浙江大学)

编写一个程序,要求用户输入24小时制的时间,而后显示12小时制的时间。

输入格式:

输入在一行中给出带有中间的“:”符号(半角的冒号)的24小时制的时间,如12:34表示12点34分。当小时或分钟数小于10时,均没有前导的零,如5:6表示5点零6分。

提示:在scanf的格式字符串中加入“:”,让scanf来处理这个冒号。

输出格式:

在一行中输出这个时间对应的12小时制的时间,数字部分格式与输入的相同,而后跟上空格,再跟上表示上午的字符串“AM”或表示下午的字符串“PM”。如“5:6 PM”表示下午5点零6分。注意,在英文的习惯中,中午12点被认为是下午,因此24小时制的12:00就是12小时制的12:0 PM;而0点被认为是次日的时间,因此是0:0 AM。

输入样例:

21:11

输出样例:

9:11 PM

#include

int main()

{

int i, j;

scanf("%d:%d", &i, &j);

if(i >= 0 && i < 12)

printf("%d:%d AM", i, j);

else if(i == 12)

printf("%d:%d PM", i, j);

else if(i == 24)

printf("%d:%d AM", i-24, j);

else

printf("%d:%d PM", i-12, j);

return 0;

}

03-4. 成绩转换(15)

时间限制

400 ms

内存限制

65536 kB

代码长度限制

8000 B

判题程序

Standard

做者

沈睿(浙江大学)

本题要求编写程序将一个百分制成绩转换为五分制成绩。转换规则:

大于等于90分为A;

小于90且大于等于80为B;

小于80且大于等于70为C;

小于70且大于等于60为D;

小于60为E。

输入格式:

输入在一行中给出1个整数的百分制成绩。

输出格式:

在一行中输出对应的五分制成绩。 输入样例: 90 输出样例: A

#include

int main()

{

int i;

scanf("%d", &i);

if(i >= 90)

printf("A");

else if(i < 90 && i >= 80)

printf("B");

else if(i < 80 && i >= 70)

printf("C");

else if(i < 70 && i >= 60)

printf("D");

else if(i < 60)

printf("E");

return 0;

}

04-0. 求符合给定条件的整数集(15)

时间限制

400 ms

内存限制

65536 kB

代码长度限制

8000 B

判题程序

Standard

做者

徐镜春(浙江大学)

给定不超过6的正整数A,考虑从A开始的连续4个数字。请输出全部由它们组成的无重复数字的3位数。

输入格式:

输入在一行中给出A。

输出格式:

输出知足条件的的3位数,要求从小到大,每行6个整数。整数间以空格分隔,但行末不能有多余空格。

输入样例:

2

输出样例:

234 235 243 245 253 254

324 325 342 345 352 354

423 425 432 435 452 453

523 524 532 534 542 543

#include

int main()

{

int A, i, j, k, p = 0;

scanf("%d", &A);

for(i=A; i

for(j=A; j

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值