PTA基础编程题目集(编程题38)

目录

7-1 厘米换算英尺英寸

7-2 然后是几点 

7-3 逆序的三位数 (10分)

7-4 BCD解密 (10分)

7-5 表格输出 

7-6 混合类型数据格式化输入 

7-7 12-24小时制 

7-8 超速判断

7-9 用天平找小球

7-10 计算工资 

7-11 分段计算居民水费

7-12 两个数的简单计算器 

7-13 日K蜡烛图

7-14 求整数段和

7-15 计算圆周率

7-16 求符合给定条件的整数集

7-17 爬动的蠕虫

7-18 二分法求多项式单根

7-19 支票面额 

7-20 九九口诀表

7-21 求特殊方程的正整数解 

7-22 龟兔赛跑 

7-23 币值转换 

7-24 约分最简分式 

7-25 念数字

7-26 单词长度

7-27 冒泡法排序

7-28 猴子选大王

7-29 删除字符串中的子串

7-30 字符串的冒泡排序

7-31 字符串循环左移

7-32 说反话-加强版

7-33 有理数加法 

7-34 通讯录的录入与显示

7-35 有理数均值 

7-36 复数四则运算

7-37 整数分解为若干项之和 

7-38 数列求和-加强版 


7-1 厘米换算英尺英寸

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

输入格式:

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

输出格式:

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

输入样例:

170

输出样例:

5 6

 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int x;8     scanf("%d",&x);9     int inch = 0.394*x;
10     printf("%d %d", inch/12, inch%12);
11     return 0;
12 }

7-2 然后是几点 

有时候人们用四位数字表示一个时间,比如1106表示11点零6分。现在,你的程序要根据起始时间和流逝的时间计算出终止时间。

读入两个数字,第一个数字以这样的四位数字表示当前时间,第二个数字表示分钟数,计算当前时间经过那么多分钟后是几点,结果也表示为四位数字。当小时为个位数时,没有前导的零,即5点30分表示为530。注意,第二个数字表示的分钟数可能超过60,也可能是负数。

输入格式:

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

输出格式:

输出四位数字表示的终止时间,当小时为个位数时,没有前导的零。题目保证起始时间和终止时间在同一天内。

输入样例:

1120 110

输出样例:

1310
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int time, minute;8     scanf("%d%d",& time,&minute);9     int t = time/100*60 + time%100 + minute;
10     printf("%d", t/60*100 + t%60);
11     return 0;
12 }

7-3 逆序的三位数 (10分)

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

输入格式:

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

输出格式:

输出按位逆序的数。

输入样例:

123

输出样例:

321
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int x;8     scanf("%d",&x);9     int sum = 0;
10     while(x)
11     {
12         sum = sum*10 + x%10;
13         x /= 10;
14     }
15     printf("%d", sum);
16     return 0;
17 }

7-4 BCD解密 (10分)

BCD数是用一个字节来表达两位十进制的数,每四个比特表示一位。所以如果一个BCD数的十六进制是0x12,它表达的就是十进制的12。但是小明没学过BCD,把所有的BCD数都当作二进制数转换成十进制输出了。于是BCD的0x12被输出成了十进制的18了!

现在,你的程序要读入这个错误的十进制数,然后输出正确的十进制数。提示:你可以把18转换回0x12,然后再转换回12。

输入格式:

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

输出格式:

输出对应的十进制数。

输入样例:

18

输出样例:

12
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int x;8     scanf("%d",&x);9     printf("%d", x/16*10+x%16);
10     return 0;
11 }

7-5 表格输出 

本题要求编写程序,按照规定格式输出表格。

输入格式:

本题目没有输入。

输出格式:

要求严格按照给出的格式输出下列表格:

------------------------------------
Province      Area(km2)   Pop.(10K)
------------------------------------
Anhui         139600.00   6461.00
Beijing        16410.54   1180.70
Chongqing      82400.00   3144.23
Shanghai        6340.50   1360.26
Zhejiang      101800.00   4894.00
------------------------------------
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     printf("------------------------------------\n");8     printf("Province      Area(km2)   Pop.(10K)\n");9     printf("------------------------------------\n");
10     printf("Anhui         139600.00   6461.00\n");
11     printf("Beijing        16410.54   1180.70\n");
12     printf("Chongqing      82400.00   3144.23\n");
13     printf("Shanghai        6340.50   1360.26\n");
14     printf("Zhejiang      101800.00   4894.00\n");
15     printf("------------------------------------\n");
16     return 0;
17 }

7-6 混合类型数据格式化输入 

本题要求编写程序,顺序读入浮点数1、整数、字符、浮点数2,再按照字符、整数、浮点数1、浮点数2的顺序输出。

输入格式:

输入在一行中顺序给出浮点数1、整数、字符、浮点数2,其间以1个空格分隔。

输出格式:

在一行中按照字符、整数、浮点数1、浮点数2的顺序输出,其中浮点数保留小数点后2位。

输入样例:

2.12 88 c 4.7

输出样例:

c 88 2.12 4.70
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     float f1,f2;8     int i;9     char c;
10     scanf("%f%d%*c%c%f",&f1,&i,&c,&f2);
11     printf("%c %i %.2f %.2f",c,i,f1,f2);
12 
13     return 0;
14 }

7-7 12-24小时制 

编写一个程序,要求用户输入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
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int h,m;8     scanf("%d:%d",&h,&m);9     if(h<12)
10         printf("%d:%d AM",h,m);
11     else if(h==12)
12         printf("%d:%d PM",h,m);
13     else
14         printf("%d:%d PM",h-12,m);
15 
16     return 0;
17 }

7-8 超速判断

模拟交通警察的雷达测速仪。输入汽车速度,如果速度超出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
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int speed;8     scanf("%d",&speed);9     if(speed<=60)
10         printf("Speed: %d - OK",speed);
11     else
12         printf("Speed: %d - Speeding",speed);
13 
14     return 0;
15 }

7-9 用天平找小球

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

输入格式:

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

输出格式:

在一行中输出唯一的那个不一样的球。

输入样例:

1 1 2

输出样例:

C

 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int A,B,C;8     scanf("%d%d%d",&A,&B,&C);9     if(A==B)
10         printf("C");
11     else{
12         if(A==C)
13             printf("B");
14         else
15             printf("A");
16     }
17 
18     return 0;
19 }

7-10 计算工资 

某公司员工的工资计算方法如下:一周内工作时间不超过40小时,按正常工作时间计酬;超出40小时的工作时间部分,按正常工作时间报酬的1.5倍计酬。员工按进公司时间分为新职工和老职工,进公司不少于5年的员工为老职工,5年以下的为新职工。新职工的正常工资为30元/小时,老职工的正常工资为50元/小时。请按该计酬方式计算员工的工资。

输入格式:

输入在一行中给出2个正整数,分别为某员工入职年数和周工作时间,其间以空格分隔。

输出格式:

在一行输出该员工的周薪,精确到小数点后2位。

输入样例1:

5 40

输出样例1:

2000.00

输入样例2:

3 50

输出样例2:

1650.00
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int y,h;8     scanf("%d%d",&y,&h);9 
10     int hs;
11     if(y>=5)
12         hs = 50;
13     else
14         hs = 30;
15 
16     double ws;
17     if(h<40)
18         ws = hs*h;
19     else
20         ws = hs*(40+(h-40)*1.5);
21 
22     printf("%.2f",ws);
23 
24     return 0;
25 }

7-11 分段计算居民水费

为鼓励居民节约用水,自来水公司采取按用水量阶梯式计价的办法,居民应交水费y(元)与月用水量x(吨)相关:当x不超过15吨时,y = 4x/3;超过后,y = 2.5x - 17.5。请编写程序实现水费的计算。

输入格式:

输入在一行中给出非负实数x。

输出格式:

在一行输出应交的水费,精确到小数点后2位。

输入样例1:

12

输出样例1:

16.00

输入样例2:

16

输出样例2:

22.50

 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int x;8     scanf("%d",&x);9 
10     double y;
11     if(x<15)
12         y = 4*x/3.0;
13     else
14         y = 2.5*x - 17.5;
15 
16     printf("%.2f",y);
17 
18     return 0;
19 }

7-12 两个数的简单计算器 

本题要求编写一个简单计算器程序,可根据输入的运算符,对2个整数进行加、减、乘、除或求余运算。题目保证输入和输出均不超过整型范围。

输入格式:

输入在一行中依次输入操作数1、运算符、操作数2,其间以1个空格分隔。操作数的数据类型为整型,且保证除法和求余的分母非零。

输出格式:

当运算符为+-*/%时,在一行输出相应的运算结果。若输入是非法符号(即除了加、减、乘、除和求余五种运算符以外的其他符号)则输出ERROR

输入样例1:

-7 / 2

输出样例1:

-3

输入样例2:

3 & 6

输出样例2:

ERROR
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int a,b;8     char c;9     scanf("%d%*c%c%d",&a,&c,&b);
10 
11     switch(c)
12     {
13     case '+':
14         printf("%d",a+b);
15         break;
16     case '-':
17         printf("%d",a-b);
18         break;
19     case '*':
20         printf("%d",a*b);
21         break;
22     case '/':
23         printf("%d",a/b);
24         break;
25     case '%':
26         printf("%d",a%b);
27         break;
28     default:
29         printf("ERROR");
30     }
31 
32     return 0;
33 }

7-13 日K蜡烛图

股票价格涨跌趋势,常用蜡烛图技术中的K线图来表示,分为按日的日K线、按周的周K线、按月的月K线等。以日K线为例,每天股票价格从开盘到收盘走完一天,对应一根蜡烛小图,要表示四个价格:开盘价格Open(早上刚刚开始开盘买卖成交的第1笔价格)、收盘价格Close(下午收盘时最后一笔成交的价格)、中间的最高价High和最低价Low。

如果Close<Open,表示为“BW-Solid”(即“实心蓝白蜡烛”);如果Close>Open,表示为“R-Hollow”(即“空心红蜡烛”);如果Open等于Close,则为“R-Cross”(即“十字红蜡烛”)。如果Low比Open和Close低,称为“Lower Shadow”(即“有下影线”),如果High比Open和Close高,称为“Upper Shadow”(即“有上影线”)。请编程序,根据给定的四个价格组合,判断当日的蜡烛是一根什么样的蜡烛。

输入格式:

输入在一行中给出4个正实数,分别对应Open、High、Low、Close,其间以空格分隔。

输出格式:

在一行中输出日K蜡烛的类型。如果有上、下影线,则在类型后加上with 影线类型。如果两种影线都有,则输出with Lower Shadow and Upper Shadow

输入样例1:

5.110 5.250 5.100 5.105

输出样例1:

BW-Solid with Lower Shadow and Upper Shadow

输入样例2:

5.110 5.110 5.110 5.110

输出样例2:

R-Cross

输入样例3:

5.110 5.125 5.112 5.126

输出样例3:

R-Hollow

 1 #include <stdio.h>2 int main()3 {4     double open,high,low,close;5     scanf("%lf%lf%lf%lf",&open,&high,&low,&close);6     if(close<open) printf("BW-Solid");7     else if(close>open) printf("R-Hollow");8     else printf("R-Cross");9     
10     if(low<open&&low<close&&high>open&&high>close)
11         printf(" with Lower Shadow and Upper Shadow");
12     else if(low<open&&low<close) 
13         printf(" with Lower Shadow");
14     else if(high>open&&high>close) 
15         printf(" with Upper Shadow");    
16     return 0;
17 }

7-14 求整数段和

给定两个整数A和B,输出从A到B的所有整数以及这些数的和。

输入格式:

输入在一行中给出2个整数A和B,其中−,其间以空格分隔。

输出格式:

首先顺序输出从A到B的所有整数,每5个数字占一行,每个数字占5个字符宽度,向右对齐。最后在一行中按Sum = X的格式输出全部数字的和X。

输入样例:

-3 8

输出样例:

   -3   -2   -1    0    1

    2    3    4    5    6

    7    8

Sum = 30

 1 #include <stdio.h>2 int main()3 {4     int a,b,sum=0,count=0;5     scanf("%d%d",&a,&b);6     for(int i=a; i<=b; ++i){7         sum += i;8         printf("%5d",i);9         count++;
10         if(count%5==0)
11             printf("\n");
12     }
13     if(count!=5) 
14         printf("\n");
15     printf("Sum = %d",sum);
16     return 0;
17 }

7-15 计算圆周率

根据下面关系式,求圆周率的值,直到最后一项的值小于给定阈值。

π​​ /2 = 1+ 1​/3​​​​ + ​2! / (3×5)​​​​ + ​3! / (3×5×7)​​ + ⋯ + ​n! / (3×5×7×⋯×(2n+1)​​​​) + ⋯

输入格式:

输入在一行中给出小于1的阈值。

输出格式:

在一行中输出满足阈值条件的近似圆周率,输出到小数点后6位。

输入样例:

0.01

输出样例:

3.132157

 1 #include <stdio.h>2 int main()3 {4     long long i=1,j=3;5     double x, num = 1, den = 3, value = num/den, sum = 1+1.0/3;6     scanf("%lf",&x);7     while(value>x){            8         num *= ++i;9         den *= (j+=2);
10         value = (double)num/den;
11         sum += value;
12     }
13     printf("%.6f",sum*2);
14     return 0;
15 }

7-16 求符合给定条件的整数集

给定不超过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
 1 #include <stdio.h>2 int main()3 {4     int a=2,count=0;5     scanf("%d",&a);6     for(int i=a; i<=a+3; i++)7     {8         for(int j=a; j<=a+3; j++){9             for(int k=a; k<=a+3; k++)
10                 if(i!=j&&i!=k&&j!=k){
11                     if(count%6)printf(" ");
12                     printf("%d%d%d",i,j,k);                    
13                     count++;
14                     if(count%6==0)        
15                         printf("\n");
16                 }        
17         }
18     }    
19     return 0;
20 }

7-17 爬动的蠕虫

一条蠕虫长1寸,在一口深为N寸的井的底部。已知蠕虫每1分钟可以向上爬U寸,但必须休息1分钟才能接着往上爬。在休息的过程中,蠕虫又下滑了D寸。就这样,上爬和下滑重复进行。请问,蠕虫需要多长时间才能爬出井?

这里要求不足1分钟按1分钟计,并且假定只要在某次上爬过程中蠕虫的头部到达了井的顶部,那么蠕虫就完成任务了。初始时,蠕虫是趴在井底的(即高度为0)。

输入格式:

输入在一行中顺序给出3个正整数N、U、D,其中D<U,N不超过100。

输出格式:

在一行中输出蠕虫爬出井的时间,以分钟为单位。

输入样例:

12 3 1

输出样例:

11

 1 /* 2 12 3 13  */4 #include <stdio.h>5 int main()6 {7     int n,u,d,t=0;8     scanf("%d%d%d",&n,&u,&d);9     while(n)
10     {
11         n -= u;
12         t++;
13         if(n<=0) break;
14         n += d;
15         t++;
16     }
17     printf("%d",t);
18     return 0;
19 }

7-18 二分法求多项式单根

二分法求函数根的原理为:如果连续函数(在区间[的两个端点取值异号,即(,则它在这个区间内至少存在1个根r,即(。

二分法的步骤为:

  • 检查区间长度,如果小于给定阈值,则停止,输出区间中点(;否则
  • 如果(,则计算中点的值(;
  • 如果(正好为0,则(就是要求的根;否则
  • 如果(与(同号,则说明根在区间[,令),重复循环;
  • 如果(与(同号,则说明根在区间[,令),重复循环。

本题目要求编写程序,计算给定3阶多项式(在给定区间[内的根。

输入格式:

输入在第1行中顺序给出多项式的4个系数a​3​​、a​2​​、a​1​​、a​0​​,在第2行中顺序给出区间端点a和b。题目保证多项式在给定区间内存在唯一单根。

输出格式:

在一行中输出该多项式在该区间内的根,精确到小数点后2位。

输入样例:

3 -1 -3 1
-0.5 0.5

输出样例:

0.33

 1 #include<stdio.h>2 #include<math.h>3 #define EPS 1e-64 float Root(float x,float a3,float a2,float a1,float a0)5 {6     return a3*x*x*x + a2*x*x + a1*x + a0;7 }8 int main()9 {
10     float a0,a1,a2,a3;
11     float min,max,mid;
12     scanf("%f%f%f%f",&a3,&a2,&a1,&a0);
13     scanf("%f%f",&min,&max);
14     do{        
15         mid=(max+min)/2.0;
16         if(Root(mid,a3,a2,a1,a0)*Root(min,a3,a2,a1,a0)>0) min = mid;
17         if(Root(mid,a3,a2,a1,a0)*Root(max,a3,a2,a1,a0)>0) max = mid;               
18     }while(fabs( Root(mid,a3,a2,a1,a0)) > EPS);
19     printf("%.2f\n",mid);
20     return 0;
21 }

7-19 支票面额 

一个采购员去银行兑换一张y元f分的支票,结果出纳员错给了f元y分。采购员用去了n分之后才发觉有错,于是清点了余额尚有2元2分,问该支票面额是多少?

输入格式:

输入在一行中给出小于100的正整数n。

输出格式:

在一行中按格式y.f输出该支票的原始面额。如果无解,则输出No Solution

输入样例1:

23

输出样例1:

25.51

输入样例2:

22

输出样例2:

No Solution
 1 #include <stdio.h>2 int main()3 {4     int n=23,flag=0;5     scanf("%d",&n);6     7     for(int y=0; y<=100; ++y){8         for(int f=0; f<=100; ++f){9             if(f*100+y - n == 2*y*100+2*f){
10                 flag=1;
11                 printf("%d.%d\n",y,f);
12             }                
13         }
14     }
15     
16     if(!flag)
17         printf("No Solution");
18     return 0;
19 }

7-20 九九口诀表

下面是一个完整的下三角九九口诀表:

1*1=1   
1*2=2   2*2=4   
1*3=3   2*3=6   3*3=9   
1*4=4   2*4=8   3*4=12  4*4=16  
1*5=5   2*5=10  3*5=15  4*5=20  5*5=25  
1*6=6   2*6=12  3*6=18  4*6=24  5*6=30  6*6=36  
1*7=7   2*7=14  3*7=21  4*7=28  5*7=35  6*7=42  7*7=49  
1*8=8   2*8=16  3*8=24  4*8=32  5*8=40  6*8=48  7*8=56  8*8=64  
1*9=9   2*9=18  3*9=27  4*9=36  5*9=45  6*9=54  7*9=63  8*9=72  9*9=81  

本题要求对任意给定的一位正整数N,输出从1*1N*N的部分口诀表。

输入格式:

输入在一行中给出一个正整数N(1≤N≤9)。

输出格式:

输出下三角N*N部分口诀表,其中等号右边数字占4位、左对齐。

输入样例:

4

输出样例:

1*1=1   
1*2=2   2*2=4   
1*3=3   2*3=6   3*3=9   
1*4=4   2*4=8   3*4=12  4*4=16
 1 #include <stdio.h>2 int main()3 {4     int n;5     scanf("%d",&n);6     7     for(int i=1; i<=n; ++i){8         for(int j=1; j<=i; ++j){9             printf("%d*%d=%-4d",j,i,i*j);
10         }
11         printf("\n");
12     }
13     return 0;
14 }

7-21 求特殊方程的正整数解 

本题要求对任意给定的正整数N,求方程X^​2​​+Y^​2​​=N的全部正整数解。

输入格式:

输入在一行中给出正整数N(≤10000)。

输出格式:

输出方程X​^2​​+Y^​2​​=N的全部正整数解,其中X≤Y。每组解占1行,两数字间以1空格分隔,按X的递增顺序输出。如果没有解,则输出No Solution

输入样例1:

884

输出样例1:

10 28
20 22

输入样例2:

11

输出样例2:

No Solution
 1 #include<stdio.h>2 int main()3 {4     int N = 884, flag = 0;5     scanf("%d",&N);6     for(int x=1; x<=N-x; ++x){7         for(int y=1; y<=N-x*x; ++y){8             if(x<y && x*x+y*y==N){9                 printf("%d %d\n",x,y);
10                 flag = 1;
11             }            
12         }    
13     }    
14     if(!flag)
15         printf("No Solution");
16     return 0;
17 }

7-22 龟兔赛跑 

乌龟与兔子进行赛跑,跑场是一个矩型跑道,跑道边可以随地进行休息。乌龟每分钟可以前进3米,兔子每分钟前进9米;兔子嫌乌龟跑得慢,觉得肯定能跑赢乌龟,于是,每跑10分钟回头看一下乌龟,若发现自己超过乌龟,就在路边休息,每次休息30分钟,否则继续跑10分钟;而乌龟非常努力,一直跑,不休息。假定乌龟与兔子在同一起点同一时刻开始起跑,请问T分钟后乌龟和兔子谁跑得快?

输入格式:

输入在一行中给出比赛时间T(分钟)。

输出格式:

在一行中输出比赛的结果:乌龟赢输出@_@,兔子赢输出^_^,平局则输出-_-;后跟1空格,再输出胜利者跑完的距离。

输入样例:

242

输出样例:

@_@ 726

 1 #include<stdio.h>2 int main()3 {4     int time;5     scanf("%d", &time);6 7     int i, rest = 0, run = 0, disrab = 0, distur = 0;8     for(i = 0; i<time; i++)9     {
10         if(run == 0){
11             run = 10;/*兔子跑十分钟*/
12             if(disrab>distur){
13                 rest = 30;/*超过了乌龟休息半小时*/
14             }
15         }
16 
17         distur += 3;/*乌龟一分钟*/        
18         if(rest == 0 ){
19             disrab += 9;/*兔子一分钟(十分钟之内)*/
20             run--;
21         }
22 
23         if(rest>0){/*兔子休息(半小时之内)*/
24             rest--;
25         }
26     }
27 
28     if(disrab<distur){
29         printf("@_@ %d",distur);
30     }
31     else if(disrab > distur){
32         printf("^_^ %d",disrab);
33     }
34     else{
35         printf("-_- %d",disrab);
36     }
37 
38     return 0;
39 }

7-23 币值转换 

输入一个整数(位数不超过9位)代表一个人民币值(单位为元),请转换成财务要求的大写中文格式。如23108元,转换后变成“贰万叁仟壹百零捌”元。为了简化输出,用小写英文字母a-j顺序代表大写数字0-9,用S、B、Q、W、Y分别代表拾、百、仟、万、亿。于是23108元应被转换输出为“cWdQbBai”元。

输入格式:

输入在一行中给出一个不超过9位的非负整数。

输出格式:

在一行中输出转换后的结果。注意“零”的用法必须符合中文习惯。

输入样例1:

813227345

输出样例1:

iYbQdBcScWhQdBeSf

输入样例2:

6900

输出样例2:

gQjB

 1 //813227345//6900//23108//100001//0    2 #include <stdio.h>3 #include <string.h>4 int main()5 {6     const char *num1 = "abcdefghij";7     const char *num2 = "GSBQWSBQY";8     char x[10] = "";    9     scanf("%s", x);    
10     
11     int start = 0;//字符串下标start
12     int end = strlen(x)-1;//字符串下标end
13     while(x[start])//当前字符
14     {
15         if(x[start]!='0'){//当前字符不为'0'
16             printf("%c",num1[x[start]-'0']);
17             if(end-start>=1)
18                 printf("%c",num2[end-start]);
19         }
20         else{//当前字符为'0', 要么输出'a', 要么输出'W'                
21             if(end-start==4) printf("%c",num2[end-start]); //且万位4,输出'W'
22             //且不到字符串尾部且下一个字符不是'0', 或字符串只一个'0'
23             else if( end > start && x[start+1]!='0' || !end )//输出'a'
24                 printf("%c",num1[x[start]-'0']);
25         } 
26         start++;
27     }    
28     return 0;
29 }

7-24 约分最简分式 

分数可以表示为分子/分母的形式。编写一个程序,要求用户输入一个分数,然后将其约分为最简分式。最简分式是指分子和分母不具有可以约分的成分了。如6/12可以被约分为1/2。当分子大于分母时,不需要表达为整数又分数的形式,即11/8还是11/8;而当分子分母相等时,仍然表达为1/1的分数形式。

输入格式:

输入在一行中给出一个分数,分子和分母中间以斜杠/分隔,如:12/34表示34分之12。分子和分母都是正整数(不包含0,如果不清楚正整数的定义的话)。

提示:在scanf的格式字符串中加入/,让scanf来处理这个斜杠。

输出格式:

在一行中输出这个分数对应的最简分式,格式与输入的相同,即采用分子/分母的形式表示分数。如 5/6表示6分之5。

输入样例:

66/120

输出样例:

11/20

 1 #include <stdio.h>2 int main()3 {4     int a,b;5     scanf("%d/%d",&a,&b);6     int t = a<b?a:b;7     while(t)8     {9         if(a%t==0&&b%t==0)
10             break;
11         t--;
12     }
13     printf("%d/%d",a/t,b/t);
14     return 0;
15 }

7-25 念数字

输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出fu字。十个数字对应的拼音如下:

0: ling
1: yi
2: er
3: san
4: si
5: wu
6: liu
7: qi
8: ba
9: jiu

输入格式:

输入在一行中给出一个整数,如:1234

提示:整数包括负数、零和正数。

输出格式:

在一行中输出这个整数对应的拼音,每个数字的拼音之间用空格分开,行末没有最后的空格。如 yi er san si

输入样例:

-600

输出样例:

fu liu ling ling
 1 #include <stdio.h>2 int main()3 {4     const char* num[10] =5         {"ling","yi","er","san","si","wu","liu","qi","ba","jiu"}; 6     char s[256] = "";7     scanf("%s",s);8     9     int index=0, flag = 0;
10     while(s[index])
11     {
12         if(flag)
13             printf(" ");
14         if(s[index]=='-')
15             printf("%s","fu");
16         else
17             printf("%s",num[s[index]-'0']);
18         index++;
19         flag = 1;
20     }
21     return 0;
22 }

7-26 单词长度


你的程序要读入一行文本,其中以空格分隔为若干个单词,以.结束。你要输出每个单词的长度。这里的单词与语言无关,可以包括各种符号,比如it's算一个单词,长度为4。注意,行中可能出现连续的空格;最后的.不计算在内。
输入格式:
输入在一行中给出一行文本,以.结束
提示:用scanf("%c",...);来读入一个字符,直到读到.为止。
输出格式:
在一行中输出这行文本对应的单词的长度,每个长度之间以空格隔开,行末没有最后的空格。
输入样例:
It's great to see you here.
输出样例:
4 5 2 3 3 4

 1 #include <stdio.h>2 int main()3 {4     char s[256] = "";5     gets(s);6     int i=0, count=0,flag=0;7     while(s[i])8     {9         if(s[i++]!=' ' && s[i-1]!='.')
10             count++;
11         else{
12             if(!count)
13                 continue;
14             if(flag)
15                 printf(" ");
16             printf("%d",count);
17             count = 0;
18             flag = 1;            
19         }        
20     }
21     return 0;
22 }

7-27 冒泡法排序


将N个整数按从小到大排序的冒泡排序法是这样工作的:从头到尾比较相邻两个元素,如果前面的元素大于其紧随的后面元素,则交换它们。通过一遍扫描,则最后一个元素必定是最大的元素。然后用同样的方法对前N−1个元素进行第二遍扫描。依此类推,最后只需处理两个元素,就完成了对N个数的排序。
本题要求对任意给定的K(<N),输出扫描完第K遍后的中间结果数列。
输入格式:
输入在第1行中给出N和K(1≤K<N≤100),在第2行中给出N个待排序的整数,数字间以空格分隔。
输出格式:
在一行中输出冒泡排序法扫描完第K遍后的中间结果数列,数字间以空格分隔,但末尾不得有多余空格。
输入样例:
6 2
2 3 5 1 6 4
输出样例:
2 1 3 4 5 6

 1 #include <stdio.h>2 int main()3 {4     int n,k;5     int arr[256] = {0};6     scanf("%d%d",&n,&k);7     for(int i=0; i<n; ++i){8         scanf("%d",&arr[i]);9     }
10     for(int i=0; i<k; ++i){
11         for(int j=1; j<n-i; ++j){
12             if(arr[j-1]>arr[j]){
13                 int t = arr[j-1];
14                 arr[j-1] = arr[j];
15                 arr[j] = t;
16             }
17         }
18     }
19     for(int i=0; i<n; ++i)
20     {
21         if(i) printf(" ");
22         printf("%d",arr[i]);
23     }
24     return 0;
25 }

7-28 猴子选大王


一群猴子要选新猴王。新猴王的选择方法是:让N只候选猴子围成一圈,从某位置起顺序编号为1~N号。从第1号开始报数,每轮从1报到3,凡报到3的猴子即退出圈子,接着又从紧邻的下一只猴子开始同样的报数。如此不断循环,最后剩下的一只猴子就选为猴王。请问是原来第几号猴子当选猴王?
输入格式:
输入在一行中给一个正整数N(≤1000)。
输出格式:
在一行中输出当选猴王的编号。
输入样例:
11
输出样例:
7

 1 #include <stdio.h>2 int main()3 {4     int arr[1000] = {0};5     int n;6     scanf("%d",&n);7     int t = n, i=0;8     int count = 0;9     while(t>1)
10     {
11         if(i==n)
12             i = 0;
13         if(!arr[i])
14             count++;
15         if(count==3){
16             count=0;
17             arr[i] = 1;
18             t--;
19         }
20         i++;
21     }
22     for(int i=0; i<n; ++i)
23         if(!arr[i]) printf("%d",i+1);
24     return 0;
25 }

7-29 删除字符串中的子串


输入2个字符串S1和S2,要求删除字符串S1中出现的所有子串S2,即结果字符串中不能包含S2。
输入格式:
输入在2行中分别给出不超过80个字符长度的、以回车结束的2个非空字符串,对应S1和S2。
输出格式:
在一行中输出删除字符串S1中出现的所有子串S2后的结果字符串。
输入样例:
Tomcat is a male ccatat
cat
输出样例:
Tom is a male

 1 /* 2 char * strcat ( char * destination, const char * source );3 destination and source shall not overlap. 4 */5 #include <stdio.h>6 #include <string.h>7 int main()8 {9     char s1[100] = "";
10     char s2[100] = "";
11     char t[100] = "";
12     gets(s1);
13     gets(s2);
14     
15     char* p = NULL;
16     while(p = strstr(s1,s2))
17     {
18         *p = '\0';
19         strcpy(t,p+strlen(s2));
20         strcat(s1,t);
21     }    
22     printf("%s",s1);    
23     return 0;
24 }

7-30 字符串的冒泡排序


我们已经知道了将N个整数按从小到大排序的冒泡排序法。本题要求将此方法用于字符串序列,并对任意给定的K(<N),输出扫描完第K遍后的中间结果序列。
输入格式:
输入在第1行中给出N和K(1≤K<N≤100),此后N行,每行包含一个长度不超过10的、仅由小写英文字母组成的非空字符串。
输出格式:
输出冒泡排序法扫描完第K遍后的中间结果序列,每行包含一个字符串。
输入样例:
6 2
best
cat
east
a
free
day
输出样例:
best
a
cat
day
east
free

 1 #include <stdio.h>2 #include <string.h>3 #define N 2564 int main()5 {6     int n,k;7     char str[N][N] = {0};8     scanf("%d%d",&n,&k);9     for(int i=0; i<n; ++i){
10         scanf("%s",&str[i]);
11     }
12     for(int i=0; i<k; ++i){
13         for(int j=1; j<n-i; ++j){
14             if(strcmp(str[j-1],str[j])>0){            
15                 char t[N] = "";
16                 strcpy(t,str[j-1]);
17                 strcpy(str[j-1],str[j]);
18                 strcpy(str[j],t);
19             }
20         }
21     }
22     for(int i=0; i<n; ++i)
23         printf("%s\n",str[i]);
24     
25     return 0;
26 }

7-31 字符串循环左移

输入一个字符串和一个非负整数N,要求将字符串循环左移N次。

输入格式:

输入在第1行中给出一个不超过100个字符长度的、以回车结束的非空字符串;第2行给出非负整数N。

输出格式:

在一行中输出循环左移N次后的字符串。

输入样例:

Hello World!
2

输出样例:

llo World!He

 1 #include <stdio.h>2 #include <string.h>3 #define N 1014 int main ()5 {6     char str[N] = "";7     int n;8     gets(str);9     scanf("%d",&n);
10     
11     int index = strlen(str)-1;
12     while(n--)
13     {
14         char ch = str[0];
15         for(int i=1; i<=index; ++i)
16             str[i-1] = str[i];
17         str[index] = ch;
18     }
19     puts(str);
20     return 0;
21 }

7-32 说反话-加强版

给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。

输入格式:

测试输入包含一个测试用例,在一行内给出总长度不超过500 000的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用若干个空格分开。

输出格式:

每个测试用例的输出占一行,输出倒序后的句子,并且保证单词间只有1个空格。

输入样例:

Hello World   Here I Come

输出样例:

Come I Here World Hello
 1 #include <stdio.h>2 #include <string.h>3 #define N 5000014 int main ()5 {6     char str[N] = "";7     gets(str);8     int count=0,flag = 0;9     char* p = str+strlen(str) - 1;
10     
11     while(p>=str)/* Hello World   Here I Come */    
12     {
13         if(*p>='a'&&*p<='z'||*p>='A'&&*p<='Z')
14         {
15             count++;
16             if(!(*(p-1)>='a'&&*(p-1)<='z'||*(p-1)>='A'&&*(p-1)<='Z')){                
17                 if(flag) printf(" ");
18                 for(int i=0; i<count; ++i)
19                     printf("%c",*(p+i));
20                 count = 0;
21                 flag = 1;
22             } 
23         }
24         p--;
25     }    
26     return 0;
27 }

7-33 有理数加法 

本题要求编写程序,计算两个有理数的和。

输入格式:

输入在一行中按照a1/b1 a2/b2的格式给出两个分数形式的有理数,其中分子和分母全是整形范围内的正整数。

输出格式:

在一行中按照a/b的格式输出两个有理数的和。注意必须是该有理数的最简分数形式,若分母为1,则只输出分子。

输入样例1:

1/3 1/6

输出样例1:

1/2

输入样例2:

4/3 2/3

输出样例2:

2
 1 #include <stdio.h>2 int main ()3 {4     int a1,b1,a2,b2;5     scanf("%d/%d%d/%d",&a1,&b1,&a2,&b2);6 7     int a = a1*b2+a2*b1;8     int b = b1*b2;9     int t = a<b?a:b;
10     while(t)
11     {
12         if(a%t==0&&b%t==0)
13             break;
14         t--;
15     }
16     if(b/t==1)
17         printf("%d",a/t);
18     else
19         printf("%d/%d",a/t,b/t);
20     return 0;
21 }

7-34 通讯录的录入与显示

通讯录中的一条记录包含下述基本信息:朋友的姓名、出生日期、性别、固定电话号码、移动电话号码。 本题要求编写程序,录入N条记录,并且根据要求显示任意某条记录。

输入格式:

输入在第一行给出正整数N(≤10);随后N行,每行按照格式姓名 生日 性别 固话 手机给出一条记录。其中姓名是不超过10个字符、不包含空格的非空字符串;生日按yyyy/mm/dd的格式给出年月日;性别用M表示“男”、F表示“女”;固话手机均为不超过15位的连续数字,前面有可能出现+

在通讯录记录输入完成后,最后一行给出正整数K,并且随后给出K个整数,表示要查询的记录编号(从0到N−1顺序编号)。数字间以空格分隔。

输出格式:

对每一条要查询的记录编号,在一行中按照姓名 固话 手机 性别 生日的格式输出该记录。若要查询的记录不存在,则输出Not Found

输入样例:

3
Chris 1984/03/10 F +86181779452 13707010007
LaoLao 1967/11/30 F 057187951100 +8618618623333
QiaoLin 1980/01/01 M 84172333 10086
2 1 7

输出样例:

LaoLao 057187951100 +8618618623333 F 1967/11/30
Not Found

 1 #include <stdio.h>2 struct address{3     char name[20];4     char birthday[20];5     char sex[20];6     char tel[20];7     char mobile[20];8 };9 int main ()
10 {
11     int n;
12     scanf("%d",&n);
13     struct address records[20];
14     for(int i=0; i<n; ++i)
15     { 
16         scanf("%s%s%s%s%s",
17             records[i].name,
18             records[i].birthday,
19             records[i].sex,
20             records[i].tel,
21             records[i].mobile);
22     }
23     /*输出 */
24     int k,record;
25     scanf("%d",&k);
26     for(int i=0; i<k; ++i)
27     {
28         scanf("%d",&record);
29         if(record>=0 && record<n)
30             printf("%s %s %s %s %s\n",
31                 records[record].name,
32                 records[record].tel,
33                 records[record].mobile,
34                 records[record].sex,
35                 records[record].birthday);            
36         else
37             printf("Not Found\n");
38     }
39     return 0;
40 }

7-35 有理数均值 

本题要求编写程序,计算N个有理数的平均值。

输入格式:

输入第一行给出正整数N(≤100);第二行中按照a1/b1 a2/b2 …的格式给出N个分数形式的有理数,其中分子和分母全是整形范围内的整数;如果是负数,则负号一定出现在最前面。

输出格式:

在一行中按照a/b的格式输出N个有理数的平均值。注意必须是该有理数的最简分数形式,若分母为1,则只输出分子。

输入样例1:

4
1/2 1/6 3/6 -5/10

输出样例1:

1/6

输入样例2:

2
4/3 2/3

输出样例2:

1
 1 #include <stdio.h>2 int reduce(int a,int b){3     int r=a%b;4     while(r!=0){5         a=b;6         b=r;7         r=a%b;8     }9     return b;
10 }
11 int main ()
12 {
13     int n, a1=0, b1=1, a2, b2, t;
14     scanf("%d",&n);
15     for(int i=0; i<n; ++i){
16         scanf("%d/%d",&a2,&b2);
17         a1 = a1*b2+a2*b1;
18         b1 = b1*b2;
19         t = reduce(a1,b1);
20         a1 /= t;
21         b1 /= t; 
22     }
23     t = reduce(a1,n*b1);
24     if(n*b1/t==1)
25         printf("%d",a1/t);
26     else
27         printf("%d/%d",a1/t,n*b1/t);
28     return 0;
29 }

7-36 复数四则运算

本题要求编写程序,计算2个复数的和、差、积、商。

输入格式:

输入在一行中按照a1 b1 a2 b2的格式给出2个复数C1=a1+b1i和C2=a2+b2i的实部和虚部。题目保证C2不为0。

输出格式:

分别在4行中按照(a1+b1i) 运算符 (a2+b2i) = 结果的格式顺序输出2个复数的和、差、积、商,数字精确到小数点后1位。如果结果的实部或者虚部为0,则不输出。如果结果为0,则输出0.0。

输入样例1:

2 3.08 -2.04 5.06

输出样例1:

(2.0+3.1i) + (-2.0+5.1i) = 8.1i
(2.0+3.1i) - (-2.0+5.1i) = 4.0-2.0i
(2.0+3.1i) * (-2.0+5.1i) = -19.7+3.8i
(2.0+3.1i) / (-2.0+5.1i) = 0.4-0.6i

输入样例2:

1 1 -1 -1.01

输出样例2:

(1.0+1.0i) + (-1.0-1.0i) = 0.0
(1.0+1.0i) - (-1.0-1.0i) = 2.0+2.0i
(1.0+1.0i) * (-1.0-1.0i) = -2.0i
(1.0+1.0i) / (-1.0-1.0i) = -1.0
 1 #include <stdio.h>2 #include <math.h>3 #define eps 1e-14 double a1,b1,a2,b2,a,b;5 void print(char op)6 {    7     printf("(%.1f%+.1fi) %c (%.1f%+.1fi) = ",a1,b1,op,a2,b2);8     if(fabs(a)<eps&&fabs(b)<eps) //是小于不是小于等于9         printf("0.0");
10     else{
11         if(fabs(a)>eps) printf("%.1f",a);//a不为0
12         if(b>0&&fabs(a)>eps&&fabs(b)>eps) printf("+");//a,b均不为0且b>0
13         if(fabs(b)>eps) printf("%.1fi",b);//b不为0
14     } 
15     printf("\n");
16 }
17 int main()
18 {  
19     scanf("%lf%lf%lf%lf",&a1,&b1,&a2,&b2);
20     /* 1.+ */
21     a = a1+a2;
22     b = b1+b2;    
23     print('+');
24     /* 2.- */
25     a = a1-a2;
26     b = b1-b2;
27     print('-');
28     /* 3.* */
29     a = a1*a2-b1*b2;
30     b = a1*b2+b1*a2;
31     print('*');
32     /* 4./ */
33     a = (a1*a2+b1*b2)/(a2*a2+b2*b2);
34     b = (b1*a2-a1*b2)/(a2*a2+b2*b2); 
35     print('/');
36     return 0;
37 }

7-37 整数分解为若干项之和 

将一个正整数N分解成几个正整数相加,可以有多种分解方法,例如7=6+1,7=5+2,7=5+1+1,…。编程求出正整数N的所有整数分解式子。

输入格式:

每个输入包含一个测试用例,即正整数N (0<N≤30)。

输出格式:

按递增顺序输出N的所有整数分解式子。递增顺序是指:对于两个分解序列N​1​​={,}和N​2​​={,},若存在i使得,,但是n​i+1​​<m​i+1​​,则N​1​​序列必定在N​2​​序列之前输出。每个式子由小到大相加,式子间用分号隔开,且每输出4个式子后换行。

输入样例:

7

输出样例:

7=1+1+1+1+1+1+1;7=1+1+1+1+1+2;7=1+1+1+1+3;7=1+1+1+2+2
7=1+1+1+4;7=1+1+2+3;7=1+1+5;7=1+2+2+2
7=1+2+4;7=1+3+3;7=1+6;7=2+2+3
7=2+5;7=3+4;7=7
 1 #include<stdio.h>2 int N = 7;3 int s[31]; // 数组栈4 int top = -1; // 数组指针 5 int count = 0; // 统计输出的次数 6 int sum = 0; // 拆分项累加和 7 8 void division (int i);9 void print();
10 int main ()
11 {
12     scanf ("%d", &N);
13     division (1);
14     return 0; 
15 }
16 void print()
17 {
18     count ++; //输出计数
19     printf("%d=", N);
20     for (int k=0; k<top; k++) 
21         printf("%d+", s[k]);//输出    
22     if (count%4 == 0 || s[top] == N) 
23         printf("%d\n", s[top]);//输出并换行
24     else 
25         printf("%d;", s[top]);//输出不换行    
26 }
27 void division (int i) //拆分 
28 {   //j<=N-sum控制sum小于等于N
29     for (int j=i; j<=N-sum; j++)
30     { 
31         s[++top] = j;//压栈
32         sum += j;    //累加                
33         division (j);//sum不等于N,递归调用,继续压栈累加
34         if(sum == N)//sum==N打印
35             print();
36         sum -= j;//退出上一个top的元素
37         top --;  //弹出上一个top的元素 
38     } 
39 }

7-38 数列求和-加强版 

给定某数字A(1)以及非负整数N(0),求数列之和S=A+AA+AAA+⋯+AA⋯A(N个A)。例如A=1, N=3时,1。

输入格式:

输入数字A与非负整数N。

输出格式:

输出其N项数列之和S的值。

输入样例:

1 3

输出样例:

123
 1 #include <stdio.h>2 int main()3 {4     int s[200000] = {0};5     int a, n, t, c = 0;6     scanf("%d%d",&a,&n);7     /* 最小n */8     if(!n)9     {
10         printf("0\n");
11         return 0;
12     }
13     /* 数列之和s的个位是a的n倍,依次递减 */
14     t = n; //n进位递增,t递减
15     for(int i=0; i<n; i++)
16     {
17         s[i] = a*t + c;//c是进位
18         if(s[i]>9)
19         {
20             c = s[i]/10;
21             s[i] %= 10;
22             if(i==n-1) n++;//进位递增
23         }
24         t--;
25     }
26     /* 从最高位读起 */
27     for(int i=n-1; i>=0; i--)
28         printf("%d",s[i]);
29     printf("\n");
30     return 0;
31 }

PTA基础编程题目集(编程题38)

目录

7-1 厘米换算英尺英寸

7-2 然后是几点 

7-3 逆序的三位数 (10分)

7-4 BCD解密 (10分)

7-5 表格输出 

7-6 混合类型数据格式化输入 

7-7 12-24小时制 

7-8 超速判断

7-9 用天平找小球

7-10 计算工资 

7-11 分段计算居民水费

7-12 两个数的简单计算器 

7-13 日K蜡烛图

7-14 求整数段和

7-15 计算圆周率

7-16 求符合给定条件的整数集

7-17 爬动的蠕虫

7-18 二分法求多项式单根

7-19 支票面额 

7-20 九九口诀表

7-21 求特殊方程的正整数解 

7-22 龟兔赛跑 

7-23 币值转换 

7-24 约分最简分式 

7-25 念数字

7-26 单词长度

7-27 冒泡法排序

7-28 猴子选大王

7-29 删除字符串中的子串

7-30 字符串的冒泡排序

7-31 字符串循环左移

7-32 说反话-加强版

7-33 有理数加法 

7-34 通讯录的录入与显示

7-35 有理数均值 

7-36 复数四则运算

7-37 整数分解为若干项之和 

7-38 数列求和-加强版 


7-1 厘米换算英尺英寸

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

输入格式:

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

输出格式:

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

输入样例:

170

输出样例:

5 6

 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int x;8     scanf("%d",&x);9     int inch = 0.394*x;
10     printf("%d %d", inch/12, inch%12);
11     return 0;
12 }

7-2 然后是几点 

有时候人们用四位数字表示一个时间,比如1106表示11点零6分。现在,你的程序要根据起始时间和流逝的时间计算出终止时间。

读入两个数字,第一个数字以这样的四位数字表示当前时间,第二个数字表示分钟数,计算当前时间经过那么多分钟后是几点,结果也表示为四位数字。当小时为个位数时,没有前导的零,即5点30分表示为530。注意,第二个数字表示的分钟数可能超过60,也可能是负数。

输入格式:

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

输出格式:

输出四位数字表示的终止时间,当小时为个位数时,没有前导的零。题目保证起始时间和终止时间在同一天内。

输入样例:

1120 110

输出样例:

1310
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int time, minute;8     scanf("%d%d",& time,&minute);9     int t = time/100*60 + time%100 + minute;
10     printf("%d", t/60*100 + t%60);
11     return 0;
12 }

7-3 逆序的三位数 (10分)

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

输入格式:

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

输出格式:

输出按位逆序的数。

输入样例:

123

输出样例:

321
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int x;8     scanf("%d",&x);9     int sum = 0;
10     while(x)
11     {
12         sum = sum*10 + x%10;
13         x /= 10;
14     }
15     printf("%d", sum);
16     return 0;
17 }

7-4 BCD解密 (10分)

BCD数是用一个字节来表达两位十进制的数,每四个比特表示一位。所以如果一个BCD数的十六进制是0x12,它表达的就是十进制的12。但是小明没学过BCD,把所有的BCD数都当作二进制数转换成十进制输出了。于是BCD的0x12被输出成了十进制的18了!

现在,你的程序要读入这个错误的十进制数,然后输出正确的十进制数。提示:你可以把18转换回0x12,然后再转换回12。

输入格式:

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

输出格式:

输出对应的十进制数。

输入样例:

18

输出样例:

12
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int x;8     scanf("%d",&x);9     printf("%d", x/16*10+x%16);
10     return 0;
11 }

7-5 表格输出 

本题要求编写程序,按照规定格式输出表格。

输入格式:

本题目没有输入。

输出格式:

要求严格按照给出的格式输出下列表格:

------------------------------------
Province      Area(km2)   Pop.(10K)
------------------------------------
Anhui         139600.00   6461.00
Beijing        16410.54   1180.70
Chongqing      82400.00   3144.23
Shanghai        6340.50   1360.26
Zhejiang      101800.00   4894.00
------------------------------------
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     printf("------------------------------------\n");8     printf("Province      Area(km2)   Pop.(10K)\n");9     printf("------------------------------------\n");
10     printf("Anhui         139600.00   6461.00\n");
11     printf("Beijing        16410.54   1180.70\n");
12     printf("Chongqing      82400.00   3144.23\n");
13     printf("Shanghai        6340.50   1360.26\n");
14     printf("Zhejiang      101800.00   4894.00\n");
15     printf("------------------------------------\n");
16     return 0;
17 }

7-6 混合类型数据格式化输入 

本题要求编写程序,顺序读入浮点数1、整数、字符、浮点数2,再按照字符、整数、浮点数1、浮点数2的顺序输出。

输入格式:

输入在一行中顺序给出浮点数1、整数、字符、浮点数2,其间以1个空格分隔。

输出格式:

在一行中按照字符、整数、浮点数1、浮点数2的顺序输出,其中浮点数保留小数点后2位。

输入样例:

2.12 88 c 4.7

输出样例:

c 88 2.12 4.70
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     float f1,f2;8     int i;9     char c;
10     scanf("%f%d%*c%c%f",&f1,&i,&c,&f2);
11     printf("%c %i %.2f %.2f",c,i,f1,f2);
12 
13     return 0;
14 }

7-7 12-24小时制 

编写一个程序,要求用户输入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
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int h,m;8     scanf("%d:%d",&h,&m);9     if(h<12)
10         printf("%d:%d AM",h,m);
11     else if(h==12)
12         printf("%d:%d PM",h,m);
13     else
14         printf("%d:%d PM",h-12,m);
15 
16     return 0;
17 }

7-8 超速判断

模拟交通警察的雷达测速仪。输入汽车速度,如果速度超出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
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int speed;8     scanf("%d",&speed);9     if(speed<=60)
10         printf("Speed: %d - OK",speed);
11     else
12         printf("Speed: %d - Speeding",speed);
13 
14     return 0;
15 }

7-9 用天平找小球

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

输入格式:

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

输出格式:

在一行中输出唯一的那个不一样的球。

输入样例:

1 1 2

输出样例:

C

 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int A,B,C;8     scanf("%d%d%d",&A,&B,&C);9     if(A==B)
10         printf("C");
11     else{
12         if(A==C)
13             printf("B");
14         else
15             printf("A");
16     }
17 
18     return 0;
19 }

7-10 计算工资 

某公司员工的工资计算方法如下:一周内工作时间不超过40小时,按正常工作时间计酬;超出40小时的工作时间部分,按正常工作时间报酬的1.5倍计酬。员工按进公司时间分为新职工和老职工,进公司不少于5年的员工为老职工,5年以下的为新职工。新职工的正常工资为30元/小时,老职工的正常工资为50元/小时。请按该计酬方式计算员工的工资。

输入格式:

输入在一行中给出2个正整数,分别为某员工入职年数和周工作时间,其间以空格分隔。

输出格式:

在一行输出该员工的周薪,精确到小数点后2位。

输入样例1:

5 40

输出样例1:

2000.00

输入样例2:

3 50

输出样例2:

1650.00
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int y,h;8     scanf("%d%d",&y,&h);9 
10     int hs;
11     if(y>=5)
12         hs = 50;
13     else
14         hs = 30;
15 
16     double ws;
17     if(h<40)
18         ws = hs*h;
19     else
20         ws = hs*(40+(h-40)*1.5);
21 
22     printf("%.2f",ws);
23 
24     return 0;
25 }

7-11 分段计算居民水费

为鼓励居民节约用水,自来水公司采取按用水量阶梯式计价的办法,居民应交水费y(元)与月用水量x(吨)相关:当x不超过15吨时,y = 4x/3;超过后,y = 2.5x - 17.5。请编写程序实现水费的计算。

输入格式:

输入在一行中给出非负实数x。

输出格式:

在一行输出应交的水费,精确到小数点后2位。

输入样例1:

12

输出样例1:

16.00

输入样例2:

16

输出样例2:

22.50

 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int x;8     scanf("%d",&x);9 
10     double y;
11     if(x<15)
12         y = 4*x/3.0;
13     else
14         y = 2.5*x - 17.5;
15 
16     printf("%.2f",y);
17 
18     return 0;
19 }

7-12 两个数的简单计算器 

本题要求编写一个简单计算器程序,可根据输入的运算符,对2个整数进行加、减、乘、除或求余运算。题目保证输入和输出均不超过整型范围。

输入格式:

输入在一行中依次输入操作数1、运算符、操作数2,其间以1个空格分隔。操作数的数据类型为整型,且保证除法和求余的分母非零。

输出格式:

当运算符为+-*/%时,在一行输出相应的运算结果。若输入是非法符号(即除了加、减、乘、除和求余五种运算符以外的其他符号)则输出ERROR

输入样例1:

-7 / 2

输出样例1:

-3

输入样例2:

3 & 6

输出样例2:

ERROR
 1 #include <stdio.h>2 #include <stdlib.h>3 #include <string.h>4 5 int main()6 {7     int a,b;8     char c;9     scanf("%d%*c%c%d",&a,&c,&b);
10 
11     switch(c)
12     {
13     case '+':
14         printf("%d",a+b);
15         break;
16     case '-':
17         printf("%d",a-b);
18         break;
19     case '*':
20         printf("%d",a*b);
21         break;
22     case '/':
23         printf("%d",a/b);
24         break;
25     case '%':
26         printf("%d",a%b);
27         break;
28     default:
29         printf("ERROR");
30     }
31 
32     return 0;
33 }

7-13 日K蜡烛图

股票价格涨跌趋势,常用蜡烛图技术中的K线图来表示,分为按日的日K线、按周的周K线、按月的月K线等。以日K线为例,每天股票价格从开盘到收盘走完一天,对应一根蜡烛小图,要表示四个价格:开盘价格Open(早上刚刚开始开盘买卖成交的第1笔价格)、收盘价格Close(下午收盘时最后一笔成交的价格)、中间的最高价High和最低价Low。

如果Close<Open,表示为“BW-Solid”(即“实心蓝白蜡烛”);如果Close>Open,表示为“R-Hollow”(即“空心红蜡烛”);如果Open等于Close,则为“R-Cross”(即“十字红蜡烛”)。如果Low比Open和Close低,称为“Lower Shadow”(即“有下影线”),如果High比Open和Close高,称为“Upper Shadow”(即“有上影线”)。请编程序,根据给定的四个价格组合,判断当日的蜡烛是一根什么样的蜡烛。

输入格式:

输入在一行中给出4个正实数,分别对应Open、High、Low、Close,其间以空格分隔。

输出格式:

在一行中输出日K蜡烛的类型。如果有上、下影线,则在类型后加上with 影线类型。如果两种影线都有,则输出with Lower Shadow and Upper Shadow

输入样例1:

5.110 5.250 5.100 5.105

输出样例1:

BW-Solid with Lower Shadow and Upper Shadow

输入样例2:

5.110 5.110 5.110 5.110

输出样例2:

R-Cross

输入样例3:

5.110 5.125 5.112 5.126

输出样例3:

R-Hollow

 1 #include <stdio.h>2 int main()3 {4     double open,high,low,close;5     scanf("%lf%lf%lf%lf",&open,&high,&low,&close);6     if(close<open) printf("BW-Solid");7     else if(close>open) printf("R-Hollow");8     else printf("R-Cross");9     
10     if(low<open&&low<close&&high>open&&high>close)
11         printf(" with Lower Shadow and Upper Shadow");
12     else if(low<open&&low<close) 
13         printf(" with Lower Shadow");
14     else if(high>open&&high>close) 
15         printf(" with Upper Shadow");    
16     return 0;
17 }

7-14 求整数段和

给定两个整数A和B,输出从A到B的所有整数以及这些数的和。

输入格式:

输入在一行中给出2个整数A和B,其中−,其间以空格分隔。

输出格式:

首先顺序输出从A到B的所有整数,每5个数字占一行,每个数字占5个字符宽度,向右对齐。最后在一行中按Sum = X的格式输出全部数字的和X。

输入样例:

-3 8

输出样例:

   -3   -2   -1    0    1

    2    3    4    5    6

    7    8

Sum = 30

 1 #include <stdio.h>2 int main()3 {4     int a,b,sum=0,count=0;5     scanf("%d%d",&a,&b);6     for(int i=a; i<=b; ++i){7         sum += i;8         printf("%5d",i);9         count++;
10         if(count%5==0)
11             printf("\n");
12     }
13     if(count!=5) 
14         printf("\n");
15     printf("Sum = %d",sum);
16     return 0;
17 }

7-15 计算圆周率

根据下面关系式,求圆周率的值,直到最后一项的值小于给定阈值。

π​​ /2 = 1+ 1​/3​​​​ + ​2! / (3×5)​​​​ + ​3! / (3×5×7)​​ + ⋯ + ​n! / (3×5×7×⋯×(2n+1)​​​​) + ⋯

输入格式:

输入在一行中给出小于1的阈值。

输出格式:

在一行中输出满足阈值条件的近似圆周率,输出到小数点后6位。

输入样例:

0.01

输出样例:

3.132157

 1 #include <stdio.h>2 int main()3 {4     long long i=1,j=3;5     double x, num = 1, den = 3, value = num/den, sum = 1+1.0/3;6     scanf("%lf",&x);7     while(value>x){            8         num *= ++i;9         den *= (j+=2);
10         value = (double)num/den;
11         sum += value;
12     }
13     printf("%.6f",sum*2);
14     return 0;
15 }

7-16 求符合给定条件的整数集

给定不超过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
 1 #include <stdio.h>2 int main()3 {4     int a=2,count=0;5     scanf("%d",&a);6     for(int i=a; i<=a+3; i++)7     {8         for(int j=a; j<=a+3; j++){9             for(int k=a; k<=a+3; k++)
10                 if(i!=j&&i!=k&&j!=k){
11                     if(count%6)printf(" ");
12                     printf("%d%d%d",i,j,k);                    
13                     count++;
14                     if(count%6==0)        
15                         printf("\n");
16                 }        
17         }
18     }    
19     return 0;
20 }

7-17 爬动的蠕虫

一条蠕虫长1寸,在一口深为N寸的井的底部。已知蠕虫每1分钟可以向上爬U寸,但必须休息1分钟才能接着往上爬。在休息的过程中,蠕虫又下滑了D寸。就这样,上爬和下滑重复进行。请问,蠕虫需要多长时间才能爬出井?

这里要求不足1分钟按1分钟计,并且假定只要在某次上爬过程中蠕虫的头部到达了井的顶部,那么蠕虫就完成任务了。初始时,蠕虫是趴在井底的(即高度为0)。

输入格式:

输入在一行中顺序给出3个正整数N、U、D,其中D<U,N不超过100。

输出格式:

在一行中输出蠕虫爬出井的时间,以分钟为单位。

输入样例:

12 3 1

输出样例:

11

 1 /* 2 12 3 13  */4 #include <stdio.h>5 int main()6 {7     int n,u,d,t=0;8     scanf("%d%d%d",&n,&u,&d);9     while(n)
10     {
11         n -= u;
12         t++;
13         if(n<=0) break;
14         n += d;
15         t++;
16     }
17     printf("%d",t);
18     return 0;
19 }

7-18 二分法求多项式单根

二分法求函数根的原理为:如果连续函数(在区间[的两个端点取值异号,即(,则它在这个区间内至少存在1个根r,即(。

二分法的步骤为:

  • 检查区间长度,如果小于给定阈值,则停止,输出区间中点(;否则
  • 如果(,则计算中点的值(;
  • 如果(正好为0,则(就是要求的根;否则
  • 如果(与(同号,则说明根在区间[,令),重复循环;
  • 如果(与(同号,则说明根在区间[,令),重复循环。

本题目要求编写程序,计算给定3阶多项式(在给定区间[内的根。

输入格式:

输入在第1行中顺序给出多项式的4个系数a​3​​、a​2​​、a​1​​、a​0​​,在第2行中顺序给出区间端点a和b。题目保证多项式在给定区间内存在唯一单根。

输出格式:

在一行中输出该多项式在该区间内的根,精确到小数点后2位。

输入样例:

3 -1 -3 1
-0.5 0.5

输出样例:

0.33

 1 #include<stdio.h>2 #include<math.h>3 #define EPS 1e-64 float Root(float x,float a3,float a2,float a1,float a0)5 {6     return a3*x*x*x + a2*x*x + a1*x + a0;7 }8 int main()9 {
10     float a0,a1,a2,a3;
11     float min,max,mid;
12     scanf("%f%f%f%f",&a3,&a2,&a1,&a0);
13     scanf("%f%f",&min,&max);
14     do{        
15         mid=(max+min)/2.0;
16         if(Root(mid,a3,a2,a1,a0)*Root(min,a3,a2,a1,a0)>0) min = mid;
17         if(Root(mid,a3,a2,a1,a0)*Root(max,a3,a2,a1,a0)>0) max = mid;               
18     }while(fabs( Root(mid,a3,a2,a1,a0)) > EPS);
19     printf("%.2f\n",mid);
20     return 0;
21 }

7-19 支票面额 

一个采购员去银行兑换一张y元f分的支票,结果出纳员错给了f元y分。采购员用去了n分之后才发觉有错,于是清点了余额尚有2元2分,问该支票面额是多少?

输入格式:

输入在一行中给出小于100的正整数n。

输出格式:

在一行中按格式y.f输出该支票的原始面额。如果无解,则输出No Solution

输入样例1:

23

输出样例1:

25.51

输入样例2:

22

输出样例2:

No Solution
 1 #include <stdio.h>2 int main()3 {4     int n=23,flag=0;5     scanf("%d",&n);6     7     for(int y=0; y<=100; ++y){8         for(int f=0; f<=100; ++f){9             if(f*100+y - n == 2*y*100+2*f){
10                 flag=1;
11                 printf("%d.%d\n",y,f);
12             }                
13         }
14     }
15     
16     if(!flag)
17         printf("No Solution");
18     return 0;
19 }

7-20 九九口诀表

下面是一个完整的下三角九九口诀表:

1*1=1   
1*2=2   2*2=4   
1*3=3   2*3=6   3*3=9   
1*4=4   2*4=8   3*4=12  4*4=16  
1*5=5   2*5=10  3*5=15  4*5=20  5*5=25  
1*6=6   2*6=12  3*6=18  4*6=24  5*6=30  6*6=36  
1*7=7   2*7=14  3*7=21  4*7=28  5*7=35  6*7=42  7*7=49  
1*8=8   2*8=16  3*8=24  4*8=32  5*8=40  6*8=48  7*8=56  8*8=64  
1*9=9   2*9=18  3*9=27  4*9=36  5*9=45  6*9=54  7*9=63  8*9=72  9*9=81  

本题要求对任意给定的一位正整数N,输出从1*1N*N的部分口诀表。

输入格式:

输入在一行中给出一个正整数N(1≤N≤9)。

输出格式:

输出下三角N*N部分口诀表,其中等号右边数字占4位、左对齐。

输入样例:

4

输出样例:

1*1=1   
1*2=2   2*2=4   
1*3=3   2*3=6   3*3=9   
1*4=4   2*4=8   3*4=12  4*4=16
 1 #include <stdio.h>2 int main()3 {4     int n;5     scanf("%d",&n);6     7     for(int i=1; i<=n; ++i){8         for(int j=1; j<=i; ++j){9             printf("%d*%d=%-4d",j,i,i*j);
10         }
11         printf("\n");
12     }
13     return 0;
14 }

7-21 求特殊方程的正整数解 

本题要求对任意给定的正整数N,求方程X^​2​​+Y^​2​​=N的全部正整数解。

输入格式:

输入在一行中给出正整数N(≤10000)。

输出格式:

输出方程X​^2​​+Y^​2​​=N的全部正整数解,其中X≤Y。每组解占1行,两数字间以1空格分隔,按X的递增顺序输出。如果没有解,则输出No Solution

输入样例1:

884

输出样例1:

10 28
20 22

输入样例2:

11

输出样例2:

No Solution
 1 #include<stdio.h>2 int main()3 {4     int N = 884, flag = 0;5     scanf("%d",&N);6     for(int x=1; x<=N-x; ++x){7         for(int y=1; y<=N-x*x; ++y){8             if(x<y && x*x+y*y==N){9                 printf("%d %d\n",x,y);
10                 flag = 1;
11             }            
12         }    
13     }    
14     if(!flag)
15         printf("No Solution");
16     return 0;
17 }

7-22 龟兔赛跑 

乌龟与兔子进行赛跑,跑场是一个矩型跑道,跑道边可以随地进行休息。乌龟每分钟可以前进3米,兔子每分钟前进9米;兔子嫌乌龟跑得慢,觉得肯定能跑赢乌龟,于是,每跑10分钟回头看一下乌龟,若发现自己超过乌龟,就在路边休息,每次休息30分钟,否则继续跑10分钟;而乌龟非常努力,一直跑,不休息。假定乌龟与兔子在同一起点同一时刻开始起跑,请问T分钟后乌龟和兔子谁跑得快?

输入格式:

输入在一行中给出比赛时间T(分钟)。

输出格式:

在一行中输出比赛的结果:乌龟赢输出@_@,兔子赢输出^_^,平局则输出-_-;后跟1空格,再输出胜利者跑完的距离。

输入样例:

242

输出样例:

@_@ 726

 1 #include<stdio.h>2 int main()3 {4     int time;5     scanf("%d", &time);6 7     int i, rest = 0, run = 0, disrab = 0, distur = 0;8     for(i = 0; i<time; i++)9     {
10         if(run == 0){
11             run = 10;/*兔子跑十分钟*/
12             if(disrab>distur){
13                 rest = 30;/*超过了乌龟休息半小时*/
14             }
15         }
16 
17         distur += 3;/*乌龟一分钟*/        
18         if(rest == 0 ){
19             disrab += 9;/*兔子一分钟(十分钟之内)*/
20             run--;
21         }
22 
23         if(rest>0){/*兔子休息(半小时之内)*/
24             rest--;
25         }
26     }
27 
28     if(disrab<distur){
29         printf("@_@ %d",distur);
30     }
31     else if(disrab > distur){
32         printf("^_^ %d",disrab);
33     }
34     else{
35         printf("-_- %d",disrab);
36     }
37 
38     return 0;
39 }

7-23 币值转换 

输入一个整数(位数不超过9位)代表一个人民币值(单位为元),请转换成财务要求的大写中文格式。如23108元,转换后变成“贰万叁仟壹百零捌”元。为了简化输出,用小写英文字母a-j顺序代表大写数字0-9,用S、B、Q、W、Y分别代表拾、百、仟、万、亿。于是23108元应被转换输出为“cWdQbBai”元。

输入格式:

输入在一行中给出一个不超过9位的非负整数。

输出格式:

在一行中输出转换后的结果。注意“零”的用法必须符合中文习惯。

输入样例1:

813227345

输出样例1:

iYbQdBcScWhQdBeSf

输入样例2:

6900

输出样例2:

gQjB

 1 //813227345//6900//23108//100001//0    2 #include <stdio.h>3 #include <string.h>4 int main()5 {6     const char *num1 = "abcdefghij";7     const char *num2 = "GSBQWSBQY";8     char x[10] = "";    9     scanf("%s", x);    
10     
11     int start = 0;//字符串下标start
12     int end = strlen(x)-1;//字符串下标end
13     while(x[start])//当前字符
14     {
15         if(x[start]!='0'){//当前字符不为'0'
16             printf("%c",num1[x[start]-'0']);
17             if(end-start>=1)
18                 printf("%c",num2[end-start]);
19         }
20         else{//当前字符为'0', 要么输出'a', 要么输出'W'                
21             if(end-start==4) printf("%c",num2[end-start]); //且万位4,输出'W'
22             //且不到字符串尾部且下一个字符不是'0', 或字符串只一个'0'
23             else if( end > start && x[start+1]!='0' || !end )//输出'a'
24                 printf("%c",num1[x[start]-'0']);
25         } 
26         start++;
27     }    
28     return 0;
29 }

7-24 约分最简分式 

分数可以表示为分子/分母的形式。编写一个程序,要求用户输入一个分数,然后将其约分为最简分式。最简分式是指分子和分母不具有可以约分的成分了。如6/12可以被约分为1/2。当分子大于分母时,不需要表达为整数又分数的形式,即11/8还是11/8;而当分子分母相等时,仍然表达为1/1的分数形式。

输入格式:

输入在一行中给出一个分数,分子和分母中间以斜杠/分隔,如:12/34表示34分之12。分子和分母都是正整数(不包含0,如果不清楚正整数的定义的话)。

提示:在scanf的格式字符串中加入/,让scanf来处理这个斜杠。

输出格式:

在一行中输出这个分数对应的最简分式,格式与输入的相同,即采用分子/分母的形式表示分数。如 5/6表示6分之5。

输入样例:

66/120

输出样例:

11/20

 1 #include <stdio.h>2 int main()3 {4     int a,b;5     scanf("%d/%d",&a,&b);6     int t = a<b?a:b;7     while(t)8     {9         if(a%t==0&&b%t==0)
10             break;
11         t--;
12     }
13     printf("%d/%d",a/t,b/t);
14     return 0;
15 }

7-25 念数字

输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出fu字。十个数字对应的拼音如下:

0: ling
1: yi
2: er
3: san
4: si
5: wu
6: liu
7: qi
8: ba
9: jiu

输入格式:

输入在一行中给出一个整数,如:1234

提示:整数包括负数、零和正数。

输出格式:

在一行中输出这个整数对应的拼音,每个数字的拼音之间用空格分开,行末没有最后的空格。如 yi er san si

输入样例:

-600

输出样例:

fu liu ling ling
 1 #include <stdio.h>2 int main()3 {4     const char* num[10] =5         {"ling","yi","er","san","si","wu","liu","qi","ba","jiu"}; 6     char s[256] = "";7     scanf("%s",s);8     9     int index=0, flag = 0;
10     while(s[index])
11     {
12         if(flag)
13             printf(" ");
14         if(s[index]=='-')
15             printf("%s","fu");
16         else
17             printf("%s",num[s[index]-'0']);
18         index++;
19         flag = 1;
20     }
21     return 0;
22 }

7-26 单词长度


你的程序要读入一行文本,其中以空格分隔为若干个单词,以.结束。你要输出每个单词的长度。这里的单词与语言无关,可以包括各种符号,比如it's算一个单词,长度为4。注意,行中可能出现连续的空格;最后的.不计算在内。
输入格式:
输入在一行中给出一行文本,以.结束
提示:用scanf("%c",...);来读入一个字符,直到读到.为止。
输出格式:
在一行中输出这行文本对应的单词的长度,每个长度之间以空格隔开,行末没有最后的空格。
输入样例:
It's great to see you here.
输出样例:
4 5 2 3 3 4

 1 #include <stdio.h>2 int main()3 {4     char s[256] = "";5     gets(s);6     int i=0, count=0,flag=0;7     while(s[i])8     {9         if(s[i++]!=' ' && s[i-1]!='.')
10             count++;
11         else{
12             if(!count)
13                 continue;
14             if(flag)
15                 printf(" ");
16             printf("%d",count);
17             count = 0;
18             flag = 1;            
19         }        
20     }
21     return 0;
22 }

7-27 冒泡法排序


将N个整数按从小到大排序的冒泡排序法是这样工作的:从头到尾比较相邻两个元素,如果前面的元素大于其紧随的后面元素,则交换它们。通过一遍扫描,则最后一个元素必定是最大的元素。然后用同样的方法对前N−1个元素进行第二遍扫描。依此类推,最后只需处理两个元素,就完成了对N个数的排序。
本题要求对任意给定的K(<N),输出扫描完第K遍后的中间结果数列。
输入格式:
输入在第1行中给出N和K(1≤K<N≤100),在第2行中给出N个待排序的整数,数字间以空格分隔。
输出格式:
在一行中输出冒泡排序法扫描完第K遍后的中间结果数列,数字间以空格分隔,但末尾不得有多余空格。
输入样例:
6 2
2 3 5 1 6 4
输出样例:
2 1 3 4 5 6

 1 #include <stdio.h>2 int main()3 {4     int n,k;5     int arr[256] = {0};6     scanf("%d%d",&n,&k);7     for(int i=0; i<n; ++i){8         scanf("%d",&arr[i]);9     }
10     for(int i=0; i<k; ++i){
11         for(int j=1; j<n-i; ++j){
12             if(arr[j-1]>arr[j]){
13                 int t = arr[j-1];
14                 arr[j-1] = arr[j];
15                 arr[j] = t;
16             }
17         }
18     }
19     for(int i=0; i<n; ++i)
20     {
21         if(i) printf(" ");
22         printf("%d",arr[i]);
23     }
24     return 0;
25 }

7-28 猴子选大王


一群猴子要选新猴王。新猴王的选择方法是:让N只候选猴子围成一圈,从某位置起顺序编号为1~N号。从第1号开始报数,每轮从1报到3,凡报到3的猴子即退出圈子,接着又从紧邻的下一只猴子开始同样的报数。如此不断循环,最后剩下的一只猴子就选为猴王。请问是原来第几号猴子当选猴王?
输入格式:
输入在一行中给一个正整数N(≤1000)。
输出格式:
在一行中输出当选猴王的编号。
输入样例:
11
输出样例:
7

 1 #include <stdio.h>2 int main()3 {4     int arr[1000] = {0};5     int n;6     scanf("%d",&n);7     int t = n, i=0;8     int count = 0;9     while(t>1)
10     {
11         if(i==n)
12             i = 0;
13         if(!arr[i])
14             count++;
15         if(count==3){
16             count=0;
17             arr[i] = 1;
18             t--;
19         }
20         i++;
21     }
22     for(int i=0; i<n; ++i)
23         if(!arr[i]) printf("%d",i+1);
24     return 0;
25 }

7-29 删除字符串中的子串


输入2个字符串S1和S2,要求删除字符串S1中出现的所有子串S2,即结果字符串中不能包含S2。
输入格式:
输入在2行中分别给出不超过80个字符长度的、以回车结束的2个非空字符串,对应S1和S2。
输出格式:
在一行中输出删除字符串S1中出现的所有子串S2后的结果字符串。
输入样例:
Tomcat is a male ccatat
cat
输出样例:
Tom is a male

 1 /* 2 char * strcat ( char * destination, const char * source );3 destination and source shall not overlap. 4 */5 #include <stdio.h>6 #include <string.h>7 int main()8 {9     char s1[100] = "";
10     char s2[100] = "";
11     char t[100] = "";
12     gets(s1);
13     gets(s2);
14     
15     char* p = NULL;
16     while(p = strstr(s1,s2))
17     {
18         *p = '\0';
19         strcpy(t,p+strlen(s2));
20         strcat(s1,t);
21     }    
22     printf("%s",s1);    
23     return 0;
24 }

7-30 字符串的冒泡排序


我们已经知道了将N个整数按从小到大排序的冒泡排序法。本题要求将此方法用于字符串序列,并对任意给定的K(<N),输出扫描完第K遍后的中间结果序列。
输入格式:
输入在第1行中给出N和K(1≤K<N≤100),此后N行,每行包含一个长度不超过10的、仅由小写英文字母组成的非空字符串。
输出格式:
输出冒泡排序法扫描完第K遍后的中间结果序列,每行包含一个字符串。
输入样例:
6 2
best
cat
east
a
free
day
输出样例:
best
a
cat
day
east
free

 1 #include <stdio.h>2 #include <string.h>3 #define N 2564 int main()5 {6     int n,k;7     char str[N][N] = {0};8     scanf("%d%d",&n,&k);9     for(int i=0; i<n; ++i){
10         scanf("%s",&str[i]);
11     }
12     for(int i=0; i<k; ++i){
13         for(int j=1; j<n-i; ++j){
14             if(strcmp(str[j-1],str[j])>0){            
15                 char t[N] = "";
16                 strcpy(t,str[j-1]);
17                 strcpy(str[j-1],str[j]);
18                 strcpy(str[j],t);
19             }
20         }
21     }
22     for(int i=0; i<n; ++i)
23         printf("%s\n",str[i]);
24     
25     return 0;
26 }

7-31 字符串循环左移

输入一个字符串和一个非负整数N,要求将字符串循环左移N次。

输入格式:

输入在第1行中给出一个不超过100个字符长度的、以回车结束的非空字符串;第2行给出非负整数N。

输出格式:

在一行中输出循环左移N次后的字符串。

输入样例:

Hello World!
2

输出样例:

llo World!He

 1 #include <stdio.h>2 #include <string.h>3 #define N 1014 int main ()5 {6     char str[N] = "";7     int n;8     gets(str);9     scanf("%d",&n);
10     
11     int index = strlen(str)-1;
12     while(n--)
13     {
14         char ch = str[0];
15         for(int i=1; i<=index; ++i)
16             str[i-1] = str[i];
17         str[index] = ch;
18     }
19     puts(str);
20     return 0;
21 }

7-32 说反话-加强版

给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。

输入格式:

测试输入包含一个测试用例,在一行内给出总长度不超过500 000的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用若干个空格分开。

输出格式:

每个测试用例的输出占一行,输出倒序后的句子,并且保证单词间只有1个空格。

输入样例:

Hello World   Here I Come

输出样例:

Come I Here World Hello
 1 #include <stdio.h>2 #include <string.h>3 #define N 5000014 int main ()5 {6     char str[N] = "";7     gets(str);8     int count=0,flag = 0;9     char* p = str+strlen(str) - 1;
10     
11     while(p>=str)/* Hello World   Here I Come */    
12     {
13         if(*p>='a'&&*p<='z'||*p>='A'&&*p<='Z')
14         {
15             count++;
16             if(!(*(p-1)>='a'&&*(p-1)<='z'||*(p-1)>='A'&&*(p-1)<='Z')){                
17                 if(flag) printf(" ");
18                 for(int i=0; i<count; ++i)
19                     printf("%c",*(p+i));
20                 count = 0;
21                 flag = 1;
22             } 
23         }
24         p--;
25     }    
26     return 0;
27 }

7-33 有理数加法 

本题要求编写程序,计算两个有理数的和。

输入格式:

输入在一行中按照a1/b1 a2/b2的格式给出两个分数形式的有理数,其中分子和分母全是整形范围内的正整数。

输出格式:

在一行中按照a/b的格式输出两个有理数的和。注意必须是该有理数的最简分数形式,若分母为1,则只输出分子。

输入样例1:

1/3 1/6

输出样例1:

1/2

输入样例2:

4/3 2/3

输出样例2:

2
 1 #include <stdio.h>2 int main ()3 {4     int a1,b1,a2,b2;5     scanf("%d/%d%d/%d",&a1,&b1,&a2,&b2);6 7     int a = a1*b2+a2*b1;8     int b = b1*b2;9     int t = a<b?a:b;
10     while(t)
11     {
12         if(a%t==0&&b%t==0)
13             break;
14         t--;
15     }
16     if(b/t==1)
17         printf("%d",a/t);
18     else
19         printf("%d/%d",a/t,b/t);
20     return 0;
21 }

7-34 通讯录的录入与显示

通讯录中的一条记录包含下述基本信息:朋友的姓名、出生日期、性别、固定电话号码、移动电话号码。 本题要求编写程序,录入N条记录,并且根据要求显示任意某条记录。

输入格式:

输入在第一行给出正整数N(≤10);随后N行,每行按照格式姓名 生日 性别 固话 手机给出一条记录。其中姓名是不超过10个字符、不包含空格的非空字符串;生日按yyyy/mm/dd的格式给出年月日;性别用M表示“男”、F表示“女”;固话手机均为不超过15位的连续数字,前面有可能出现+

在通讯录记录输入完成后,最后一行给出正整数K,并且随后给出K个整数,表示要查询的记录编号(从0到N−1顺序编号)。数字间以空格分隔。

输出格式:

对每一条要查询的记录编号,在一行中按照姓名 固话 手机 性别 生日的格式输出该记录。若要查询的记录不存在,则输出Not Found

输入样例:

3
Chris 1984/03/10 F +86181779452 13707010007
LaoLao 1967/11/30 F 057187951100 +8618618623333
QiaoLin 1980/01/01 M 84172333 10086
2 1 7

输出样例:

LaoLao 057187951100 +8618618623333 F 1967/11/30
Not Found

 1 #include <stdio.h>2 struct address{3     char name[20];4     char birthday[20];5     char sex[20];6     char tel[20];7     char mobile[20];8 };9 int main ()
10 {
11     int n;
12     scanf("%d",&n);
13     struct address records[20];
14     for(int i=0; i<n; ++i)
15     { 
16         scanf("%s%s%s%s%s",
17             records[i].name,
18             records[i].birthday,
19             records[i].sex,
20             records[i].tel,
21             records[i].mobile);
22     }
23     /*输出 */
24     int k,record;
25     scanf("%d",&k);
26     for(int i=0; i<k; ++i)
27     {
28         scanf("%d",&record);
29         if(record>=0 && record<n)
30             printf("%s %s %s %s %s\n",
31                 records[record].name,
32                 records[record].tel,
33                 records[record].mobile,
34                 records[record].sex,
35                 records[record].birthday);            
36         else
37             printf("Not Found\n");
38     }
39     return 0;
40 }

7-35 有理数均值 

本题要求编写程序,计算N个有理数的平均值。

输入格式:

输入第一行给出正整数N(≤100);第二行中按照a1/b1 a2/b2 …的格式给出N个分数形式的有理数,其中分子和分母全是整形范围内的整数;如果是负数,则负号一定出现在最前面。

输出格式:

在一行中按照a/b的格式输出N个有理数的平均值。注意必须是该有理数的最简分数形式,若分母为1,则只输出分子。

输入样例1:

4
1/2 1/6 3/6 -5/10

输出样例1:

1/6

输入样例2:

2
4/3 2/3

输出样例2:

1
 1 #include <stdio.h>2 int reduce(int a,int b){3     int r=a%b;4     while(r!=0){5         a=b;6         b=r;7         r=a%b;8     }9     return b;
10 }
11 int main ()
12 {
13     int n, a1=0, b1=1, a2, b2, t;
14     scanf("%d",&n);
15     for(int i=0; i<n; ++i){
16         scanf("%d/%d",&a2,&b2);
17         a1 = a1*b2+a2*b1;
18         b1 = b1*b2;
19         t = reduce(a1,b1);
20         a1 /= t;
21         b1 /= t; 
22     }
23     t = reduce(a1,n*b1);
24     if(n*b1/t==1)
25         printf("%d",a1/t);
26     else
27         printf("%d/%d",a1/t,n*b1/t);
28     return 0;
29 }

7-36 复数四则运算

本题要求编写程序,计算2个复数的和、差、积、商。

输入格式:

输入在一行中按照a1 b1 a2 b2的格式给出2个复数C1=a1+b1i和C2=a2+b2i的实部和虚部。题目保证C2不为0。

输出格式:

分别在4行中按照(a1+b1i) 运算符 (a2+b2i) = 结果的格式顺序输出2个复数的和、差、积、商,数字精确到小数点后1位。如果结果的实部或者虚部为0,则不输出。如果结果为0,则输出0.0。

输入样例1:

2 3.08 -2.04 5.06

输出样例1:

(2.0+3.1i) + (-2.0+5.1i) = 8.1i
(2.0+3.1i) - (-2.0+5.1i) = 4.0-2.0i
(2.0+3.1i) * (-2.0+5.1i) = -19.7+3.8i
(2.0+3.1i) / (-2.0+5.1i) = 0.4-0.6i

输入样例2:

1 1 -1 -1.01

输出样例2:

(1.0+1.0i) + (-1.0-1.0i) = 0.0
(1.0+1.0i) - (-1.0-1.0i) = 2.0+2.0i
(1.0+1.0i) * (-1.0-1.0i) = -2.0i
(1.0+1.0i) / (-1.0-1.0i) = -1.0
 1 #include <stdio.h>2 #include <math.h>3 #define eps 1e-14 double a1,b1,a2,b2,a,b;5 void print(char op)6 {    7     printf("(%.1f%+.1fi) %c (%.1f%+.1fi) = ",a1,b1,op,a2,b2);8     if(fabs(a)<eps&&fabs(b)<eps) //是小于不是小于等于9         printf("0.0");
10     else{
11         if(fabs(a)>eps) printf("%.1f",a);//a不为0
12         if(b>0&&fabs(a)>eps&&fabs(b)>eps) printf("+");//a,b均不为0且b>0
13         if(fabs(b)>eps) printf("%.1fi",b);//b不为0
14     } 
15     printf("\n");
16 }
17 int main()
18 {  
19     scanf("%lf%lf%lf%lf",&a1,&b1,&a2,&b2);
20     /* 1.+ */
21     a = a1+a2;
22     b = b1+b2;    
23     print('+');
24     /* 2.- */
25     a = a1-a2;
26     b = b1-b2;
27     print('-');
28     /* 3.* */
29     a = a1*a2-b1*b2;
30     b = a1*b2+b1*a2;
31     print('*');
32     /* 4./ */
33     a = (a1*a2+b1*b2)/(a2*a2+b2*b2);
34     b = (b1*a2-a1*b2)/(a2*a2+b2*b2); 
35     print('/');
36     return 0;
37 }

7-37 整数分解为若干项之和 

将一个正整数N分解成几个正整数相加,可以有多种分解方法,例如7=6+1,7=5+2,7=5+1+1,…。编程求出正整数N的所有整数分解式子。

输入格式:

每个输入包含一个测试用例,即正整数N (0<N≤30)。

输出格式:

按递增顺序输出N的所有整数分解式子。递增顺序是指:对于两个分解序列N​1​​={,}和N​2​​={,},若存在i使得,,但是n​i+1​​<m​i+1​​,则N​1​​序列必定在N​2​​序列之前输出。每个式子由小到大相加,式子间用分号隔开,且每输出4个式子后换行。

输入样例:

7

输出样例:

7=1+1+1+1+1+1+1;7=1+1+1+1+1+2;7=1+1+1+1+3;7=1+1+1+2+2
7=1+1+1+4;7=1+1+2+3;7=1+1+5;7=1+2+2+2
7=1+2+4;7=1+3+3;7=1+6;7=2+2+3
7=2+5;7=3+4;7=7
 1 #include<stdio.h>2 int N = 7;3 int s[31]; // 数组栈4 int top = -1; // 数组指针 5 int count = 0; // 统计输出的次数 6 int sum = 0; // 拆分项累加和 7 8 void division (int i);9 void print();
10 int main ()
11 {
12     scanf ("%d", &N);
13     division (1);
14     return 0; 
15 }
16 void print()
17 {
18     count ++; //输出计数
19     printf("%d=", N);
20     for (int k=0; k<top; k++) 
21         printf("%d+", s[k]);//输出    
22     if (count%4 == 0 || s[top] == N) 
23         printf("%d\n", s[top]);//输出并换行
24     else 
25         printf("%d;", s[top]);//输出不换行    
26 }
27 void division (int i) //拆分 
28 {   //j<=N-sum控制sum小于等于N
29     for (int j=i; j<=N-sum; j++)
30     { 
31         s[++top] = j;//压栈
32         sum += j;    //累加                
33         division (j);//sum不等于N,递归调用,继续压栈累加
34         if(sum == N)//sum==N打印
35             print();
36         sum -= j;//退出上一个top的元素
37         top --;  //弹出上一个top的元素 
38     } 
39 }

7-38 数列求和-加强版 

给定某数字A(1)以及非负整数N(0),求数列之和S=A+AA+AAA+⋯+AA⋯A(N个A)。例如A=1, N=3时,1。

输入格式:

输入数字A与非负整数N。

输出格式:

输出其N项数列之和S的值。

输入样例:

1 3

输出样例:

123
 1 #include <stdio.h>2 int main()3 {4     int s[200000] = {0};5     int a, n, t, c = 0;6     scanf("%d%d",&a,&n);7     /* 最小n */8     if(!n)9     {
10         printf("0\n");
11         return 0;
12     }
13     /* 数列之和s的个位是a的n倍,依次递减 */
14     t = n; //n进位递增,t递减
15     for(int i=0; i<n; i++)
16     {
17         s[i] = a*t + c;//c是进位
18         if(s[i]>9)
19         {
20             c = s[i]/10;
21             s[i] %= 10;
22             if(i==n-1) n++;//进位递增
23         }
24         t--;
25     }
26     /* 从最高位读起 */
27     for(int i=n-1; i>=0; i--)
28         printf("%d",s[i]);
29     printf("\n");
30     return 0;
31 }