PAT测试 cccc竞赛

L1-3. 个位数统计

时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
陈越

给定一个k位整数N = dk-1*10k-1 + ... + d1*101 + d0 (0<=di<=9, i=0,...,k-1, dk-1>0),请编写程序统计每种不同的个位数字出现的次数。例如:给定N = 100311,则有2个0,3个1,和1个3。

输入格式:

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

输出格式:

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

输入样例:
100311
输出样例:
0:2
1:3
3:1

提交代

#include<iostream>
#include<cmath>
#include<cstdio>
#include<cstring>
using namespace std;
int main()
{
    char a[1001];
    int b[1001]= {0};
    gets(a);
    int len=strlen(a);
    if(a[0]=='0'&&len==1)
        cout<<"0:0"<<endl;
    for(int i=0; i<len; i++)
    {
        b[a[i]-'0']++;
    }
    for(int j=0; j<10; j++)
        if(b[j])
            cout<<j<<":"<<b[j]<<endl;
    return 0;
}















L1-2. 打印沙漏

时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
陈越

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

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

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

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

输入格式:

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

输出格式:

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

输入样例:
19 *
输出样例:
*****
 ***
  *
 ***
*****
2

提交代码

#include <iostream>
#include<cstdio>
#include<string.h>
#include<cmath>
using namespace std;
int main()
{
    int n,i;
    char ch;
    scanf("%d %c",&n,&ch);
    for( i=0;; i++)
        if(n>=2*i*i-1&&n<2*(i+1)*(i+1)-1)
            break;
    int len=i;///len==3
    for(int i=0; i<len; i++)
    {
        for(int j=0; j<i; j++)
            cout<<" ";
        for(int k=0; k<2*(len-i)-1; k++)
            cout<<ch;
        cout<<endl;

    }
    for(int i=0;i<len-1;i++)

    {
        for(int j=0;j<=len-i-3;j++)
        cout<<" ";
        for(int k=0;k<2*i+3;k++)
            cout<<ch;
        cout<<endl;

    }
    cout<<n-2*i*i+1<<endl;
    return 0;
}








L1-5. 考试座位号

时间限制
200 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
陈越

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

输入格式:

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

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

输出格式:

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

输入样例:
4
10120150912233 2 4
10120150912119 4 1
10120150912126 1 3
10120150912002 3 2
2
3 4
输出样例:
10120150912002 2
10120150912119 1

提交代码

#include <iostream>
#include<cstdio>
using namespace std;
struct node
{
    char n1[15];
    int n2,n3;
};
int main()
{
    int n,t,x;
    cin>>n;
    node a[1001];
    for(int i=0;i<n;i++)
    {
        scanf("%s %d %d",a[i].n1,&a[i].n2,&a[i].n3);
    }
    cin>>t;
    while(t--)
    {
        cin>>x;
        for(int i=0;i<n;i++)
        if(x==a[i].n2)
        printf("%s %d\n",a[i].n1,a[i].n3);
    }
    return 0;
}








L1-7. 念数字

时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
翁恺

输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出“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

提交代码

注意考虑输入为0的情况

#include <iostream>
#include<cstdio>
#include<string.h>
#include<cmath>
using namespace std;
int b[10]={0};
int c[10]={0};
int main()
{
    long long  x;
    cin>>x;
    if(x==0)
        cout<<"ling"<<endl;
    if(x<0)
        cout<<"fu ";
    int len=0;
        long long  a=abs(x);
    while(a)
    {
        b[len++]=a%10;
        a/=10;
    }
    for(int i=0;i<len;i++)
        c[i]=b[len-1-i];

   for(int i=0;i<len;i++)
   {
        switch(c[i])
        {
            case 0:cout<<"ling";break;
            case 1:cout<<"yi";break;
            case 2:cout<<"er";break;
            case 3:cout<<"san";break;
            case 4:cout<<"si";break;
            case 5:cout<<"wu";break;   
            case 6:cout<<"liu";break;
            case 7:cout<<"qi";break;
            case 8:cout<<"ba";break;
            case 9:cout<<"jiu";break;

        }

        if(i<len-1)
                cout<<" ";
   }
    return 0;
}










L1-8. 求整数段和

时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
杨起帆

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

输入格式:

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

输出格式:

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

输入样例:
-3 8
输出样例:
   -3   -2   -1    0    1
    2    3    4    5    6
    7    8
Sum = 30

提交代码



提交代码
 
注意处理细节
<pre name="code" class="cpp">#include <iostream>
#include<cstdio>
#include<string.h>
#include<cmath>
using namespace std;
int main()
{
    int a,b;
    cin>>a>>b;
    int sum=0;
    int count=0;
    for(int i=a; i<=b; i++)
    {
        printf("%5d",i);
        count++;
        if(count%5==0&&i!=b)
        {
            cout<<endl;
        }
        sum+=i;
    }
    cout<<endl;
    printf("Sum = %d\n",sum);

    return 0;
}


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值