团体程序设计天梯赛-练习集

L1-001

Hello World

这道超级简单的题目没有任何输入。

你只需要在一行中输出著名短句“Hello World!”就可以了。

输入样例:

输出样例:

Hello World!

1 #include<stdio.h>
2 int main()
3 {
4     printf("Hello World!");
5     return 0;
6 }

L1-002

打印沙漏

本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印

*****
 ***
  *
 ***
*****
 

所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。

给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。

输入格式:

输入在一行给出1个正整数N(≤1000)和一个符号,中间以空格分隔。

输出格式:

首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。

输入样例:

19 *
 

输出样例:

*****
 ***
  *
 ***
*****
2


下方的代码中,注意ret,n中需要有一个不能变,用于最后判断剩余几个

 1 #include<stdio.h>
 2 #include<math.h>
 3 
 4 int main()
 5 {
 6     char a; 
 7     int n,N;
 8     int res=0,ret=0;
 9     scanf("%d %c",&N,&a);
10     for(n=0;;n++){
11         if(N>=2*pow(n,2)-1&&N<2*pow(n+1,2)-1){
12             res=n;
13             break;
14         }
15     }//得出最大沙漏对应的参数
16     int m,i;
17     for (m = 0;m < n;m ++){
18         for(i = 0;i < m;i ++) printf(" ");
19         for(i = 0;i < 2*res-1;i ++){
20             printf("%c",a);
21         }
22         res--; 
23         printf("
");
24     }
25     for (m = 0;m < n-1;m ++){ 
26         for(i = m;i < n-2;i ++) printf(" ");
27         for(i = 0;i < 2*res+3;i++){
28             printf("%c",a);
29         }
30         res++;
31         putchar('
');
32     }
33     ret = N - 2*pow(n,2)+1;
34     if (ret != 0)    printf("%d
",ret);
35     return 0;
36 }
不知道怎么肥四,显示部分正确,扣了两分...

 

原来如此!

我们经常也能在编译器中看到到未处理scanf返回值的警告,但我们往往选择忽略.
首先scanf 函数的返回值反映了按照指定的格式符正确读入的数据的个数。不一定等于得到输入值的输入项的个数,也不是进入缓冲区的数据的个数。
如果输入数据与指定格式不符,则会产生输入错误。遇到输入错误,scanf函数会立即终止,返回已经成功读取的数据(即正确读入)的个数。
所以,通过scanf函数的返回值和指定输入数据的个数(由格式符决定)的比较,可以判断数据输入是否成功。
j就安全性来说在大多数情况下不应忽略 scanf 的返回值,所以他们给了它一个属性 warn_unused_result ,告诉编译器给你一个警告,如果返回值真的不需要,那么就没问题。不过,通常最好检查一下,以确保你确实成功地读取了你认为自己读取的内容。

 这有一些阐释Warning: ignoring return value of 'scanf', declared with attribute warn_unused_result | 易学教程 (e-learn.cn)



L1-003
个位数统计

输入格式:

每个输入包含 1 个测试用例,即一个不超过 1000 位的正整数 N。

输出格式:

对 N 中每一种不同的个位数字,以 D:M 的格式在一行中输出该位数字 D 及其在 N 中出现的次数 M。要求按 D 的升序输出。

输入样例:

100311
 

输出样例:

0:2
1:3
3:1


 1 #include<stdio.h>
 2 #include<string.h>
 3 
 4 int main()
 5 {
 6     char a[1000];
 7     scanf("%s", a);
 8     int len = strlen(a);
 9     int i,num_[10]={0};
10     for (i=0;i<len;i ++){
11         num_[a[i]-'0']++;
12     } 
13     for (i=0;i<10;i ++){
14         if(num_[i]!=0)
15             printf("%d:%d
",i,num_[i]);
16     }
17     return 0;
18 }
L1-004
计算摄氏温度

给定一个华氏温度F,本题要求编写程序,计算对应的摄氏温度C。计算公式:C=5*(F-32)/9。题目保证输入与输出均在整型范围内。

输入格式:

输入在一行中给出一个华氏温度。

输出格式:

在一行中按照格式“Celsius = C”输出对应的摄氏温度C的整数值。

输入样例:

150
 

输出样例:

Celsius = 65
 
 

1 #include<stdio.h>
2 int main()
3 {
4     int f,c;
5     scanf("%d",&f);
6     c = 5*(f-32)/9;
7     printf("Celsius = %d
",c);
8     return 0;
9 }



L1-005
考试座位号

每个 PAT 考生在参加考试时都会被分配两个座位号,一个是试机座位,一个是考试座位。正常情况下,考生在入场时先得到试机座位号码,入座进入试机状态后,系统会显示该考生的考试座位号码,考试时考生需要换到考试座位就座。但有些考生迟到了,试机已经结束,他们只能拿着领到的试机座位号码求助于你,从后台查出他们的考试座位号码。

输入格式:

输入第一行给出一个正整数 N(≤),随后 N 行,每行给出一个考生的信息:准考证号 试机座位号 考试座位号。其中准考证号由 16 位数字组成,座位从 1 到 N 编号。输入保证每个人的准考证号都不同,并且任何时候都不会把两个人分配到同一个座位上。

考生信息之后,给出一个正整数 M(≤),随后一行中给出 M 个待查询的试机座位号码,以空格分隔。

输出格式:

对应每个需要查询的试机座位号码,在一行中输出对应考生的准考证号和考试座位号码,中间用 1 个空格分隔。

输入样例:

4
3310120150912233 2 4
3310120150912119 4 1
3310120150912126 1 3
3310120150912002 3 2
2
3 4
 

输出样例:

3310120150912002 2
3310120150912119 1
 
 
 
L1-007 
念数字 
 

输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出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 #include<string.h>
 3 
 4 int main()
 5 {
 6     char a[100];
 7     scanf("%s",a);
 8     int len = strlen(a)-1;
 9     for (int i=0;i<=len;i++){
10         switch(a[i]){
11             case '-':printf("fu");break;
12             case '5':printf("wu");break;
13             case '4':printf("si");break;
14             case '6':printf("liu");break;
15             case '3':printf("san");break;
16             case '7':printf("qi");break;
17             case '2':printf("er");break;
18             case '8':printf("ba");break;
19             case '1':printf("yi");break;
20             case '9':printf("jiu");break;
21             case '0':printf("ling");break;
22             default:break;
23         }
24         if(i!=len) printf(" ");
25         else putchar('
');
26     }
27     return 0;
28 }
 


天涯犹在,不诉薄凉。
原文地址:https://www.cnblogs.com/Knight02/p/14089240.html