zoukankan      html  css  js  c++  java
  • 团体程序设计天梯赛-练习集

    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 }
     


    天涯犹在,不诉薄凉。
  • 相关阅读:
    C++实现多项式曲线拟合--polyfit-超定方程
    C# XmlDocument操作XML
    C#下使用XmlDocument详解
    前端常见的9种设计模式
    前端常用的设计模式
    前端需要了解的9种设计模式
    TCP协议详解
    请UI小姐姐喝了一杯奶茶要来的网站
    nodemon 基本配置与使用
    wireshark抓包新手使用教程
  • 原文地址:https://www.cnblogs.com/Knight02/p/14089240.html
Copyright © 2011-2022 走看看