PTA 团体程序设计天梯赛-练习集L1(1~50)

文章目录

  • -----------------------------------------------1~10-----------------------------------------------
  • L1-001 Hello World
  • L1-002 打印沙漏
  • L1-003 个位数统计
  • L1-004 计算摄氏温度
  • L1-005 考试座位号
  • L1-006 连续因子
  • L1-007 念数字
  • L1-008 求整数段和
  • L1-009 N个数求和
  • L1-010 比较大小
  • ----------------------------------------------11~20----------------------------------------------
  • L1-011 A-B
  • L1-012 计算指数
  • L1-013 计算阶乘和
  • L1-014 简单题
  • L1-015 跟奥巴马一起画方块
  • L1-016 查验身份证
  • L1-017 到底有多二
  • L1-018 大笨钟
  • L1-019 谁先倒
  • L1-020 帅到没朋友
  • ----------------------------------------------21~30----------------------------------------------
  • L1-021 重要的话说三遍
  • L1-022 奇偶分家
  • L1-023 输出GPLT
  • L1-024 后天
  • L1-025 正整数A+B
  • L1-026 I Love GPLT
  • L1-027 出租
  • L1-028 判断素数
  • L1-029 是不是太胖了
  • L1-030 一帮一
  • ----------------------------------------------31~40----------------------------------------------
  • L1-031 到底是不是太胖了
  • L1-032 Left-pad
  • L1-033 出生年
  • ----------------------------------------------41~50----------------------------------------------

-----------------------------------------------1~10-----------------------------------------------

L1-001 Hello World

这道超级简单的题目没有任何输入。
你只需要在一行中输出著名短句“Hello World!”就可以了。

输入样例:

输出样例:

Hello World!

大意

直接输出  Hello World!

思路

直接输出

答案

#include 
using namespace std;

int main()
{
    cout << "Hello World!" << endl;
    return 0;
}

L1-002 打印沙漏

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

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

所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。
给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。

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

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

输入样例:

19 *

输出样例:

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

大意

在一定数量的指定字符条件下,组成该数量下所能组成的最大层数的字符沙漏,并输出剩余字符数量。

思路


答案

#include 
#include

using namespace std;

int main()
{
    int n;
    char c;
    int i,line=0;
    cin>>n>>c;
    line=(int)sqrt(2*n+2)-1;
    line=(line-1)/2;
    for(i=line; i>=1; i--)
    {
        for(int k=line-i; k>=1; k--)
            cout<<" ";
        for(int j=i*2+1; j>=1; j--)
        {
            cout<<c;
        }
        cout<<endl;
    }
    for(i=0; i<line; i++)
    {
        cout<<" ";
    }
    cout<<c<<endl;
    for(i=1; i<=line; i++)
    {
        for(int k=line-i; k>=1; k--)
            cout<<" ";
        for(int j=i*2+1; j>=1; j--)
        {
            cout<<c;
        }
        cout<<endl;
    }
    cout<<(n-(2*line*(line+2)+1));
    return 0;
}

L1-003 个位数统计

给定一个 k 位整数,请编写程序统计每种不同的个位数字出现的次数。例如:给定 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

大意

计算给出的数字中,各个数字出现的次数,并输出。

思路

第一、不超过 1000 位的正整数 N,表明了不能使用int类型(long long int 也不行),
只能使用字符串类型。将输入存入字符串中之后,拿到长度,遍历字符串。
使用ascall码和数组记录出现的次数。最后输出。

答案(C)

#include
#include 
int main()
{   char s[1005];
    int a[15]={0};
    int len,t;
        scanf("%s",s);
        len=strlen(s);
        t=0;
        for(int i=0;i<len;i++)
        {
            t=s[i]-48;
            a[t]++;
            //PRintf("gg: %d,%d\n",t,i);
        }

        for(int j=0;j<10;j++)
        {
            if(a[j]!=0)
            {
                printf("%d:%d\n",j,a[j]);
            }
        }
}

L1-004 计算摄氏温度

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

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

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

输入样例:

150

输出样例:

Celsius = 65

大意

给定一个华氏温度,根据公式,计算对应的摄氏温度。

思路

直接套公式算。然后输出。

答案

#include 

using namespace std;

int main()
{
    int f;
    cin >> f;
    int c;
    c=(f-32)*5/9;
    cout <<"Celsius = "<< c << endl;
    return 0;
}

L1-005 考试座位号

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

输入格式:
输入第一行给出一个正整数 N(≤1000),随后 N 行,每行给出一个考生的信息:

准考证号 试机座位号 考试座位号

其中准考证号由 16 位数字组成,座位从 1 到 N 编号。输入保证每个人的准考证号都不同,并且任何时候都不会把两个人分配到同一个座位上。

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

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

输入样例:

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

输出样例:

3310120150912002 2
3310120150912119 1

大意

输入,给出了所有人的准考证号、试机座位号、考试座位号。
接着给出了几个不知道考试座位号的人的准考证号、试机座位号的信息。
输出与该准考证号对应的考试座位号。

思路

2个以上的数据,使用结构体存储相关信息。
用结构体存储全部信息,用数组存储要求求的人的试机座位号信息。
双层遍历,按要求输出。

答案

#include 
#include 

using namespace std;

struct person
{
    string n;
    int  a;
    int  m;
};

int main()
{
    int x;
    cin >> x;
    person p[x];
    int i;
    for(i=0; i<x; i++)
    {
        cin >> p[i].n >> p[i].a >> p[i].m;
    }

    int y;
    cin >> y;
    int c[y];
    for(i=0; i<y; i++)
    {
        cin >> c[i];
    }

    int j=0;
    for(j=0; j<y; j++)
    {
        for(i=0;i<x;i++)
        {
            if(p[i].a==c[j])
            {
                cout << p[i].n << ' ' <<p[i].m <<endl;
            }
        }
    }
    return 0;
}

L1-006 连续因子

一个正整数 N 的因子中可能存在若干连续的数字。例如 630 可以分解为 3×5×6×7,其中 5、6、7 就是 3 个连续的数字。给定任一正整数 N,要求编写程序求出最长连续因子的个数,并输出最小的连续因子序列。

输入格式:
输入在一行中给出一个正整数 N(1

输出格式:
首先在第 1 行输出最长连续因子的个数;然后在第 2 行中按 因子1因子2……*因子k 的格式输出最小的连续因子序列,其中因子按递增顺序输出,1 不算在内。

输入样例:

630

输出样例:

3
5*6*7

大意


思路


答案

#include
#include

using namespace std;

int main()
{
    int n,q,t=0;
    int i,j,cnt,stop=1,s;
    int list[1010],temp[1010];
    cin >> n;
    q=(int)sqrt(n)+1;
    for(i=q; i>=2&&stop; i--)
    {
        s=n;
        if(s%i==0)
        {
            cnt=0;
            temp[cnt++]=i;
            s=s/i;
            for(j=i-1; s%j==0&&j>=2; j--)
            {
                temp[cnt++]=j;
                s=s/j;
                if(j==2)
                {
                    stop=0;
                }
            }
            if(cnt>=t)
            {
                t=cnt;
                for(j=0; j<t; j++)
                    list[j]=temp[j];
            }
        }
    }
    if(t==0)
        cout<<"1"<<endl<<n;
    else
    {
        cout<<t<<endl;
        for(j=t-1; j>=0; j--)
        {
            cout<<list[j];
            if(j!=0)
              {
                 cout<<"*";
              }
            else
             {
                 cout<<endl;
             }
        }
    }
    return 0;
}

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

大意

给出整数,输出整数的拼音。

思路

字符串存储,遍历判断输出。
12个判断,最后一个判断是否输入空格。

答案

#include 
#include 

using namespace std;

int main()
{
    string s;
    cin >>s;
    int l;
    l=s.length();

    int i;
    for(i=0; i<l; i++)
    {
        if(s[i]=='-')
        {
            cout <<"fu";
        }
        if(s[i]=='0')
        {
            cout << "ling";
        }
        if(s[i]=='1')
        {
            cout <<"yi";
        }
        if(s[i]=='2')
        {
            cout <<"er";
        }
        if(s[i]=='3')
        {
            cout <<"san";
        }
        if(s[i]=='4')
        {
            cout <<"si";
        }
        if(s[i]=='5')
        {
            cout <<"wu";
        }
        if(s[i]=='6')
        {
            cout <<"liu";
        }
        if(s[i]=='7')
        {
            cout <<"qi";
        }
        if(s[i]=='8')
        {
            cout <<"ba";
        }
        if(s[i]=='9')
        {
            cout <<"jiu";
        }
        if(i!=l-1)
        {
            cout <<" ";
        }
    }
    return 0;
}

L1-008 求整数段和

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

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

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

输入样例:

-3 8

输出样例:

   -3   -2   -1    0    1
    2    3    4    5    6
    7    8
Sum = 30

大意

输入x,y两个数,输出这两个数之间的所有数,并求和。

思路

从x遍历到y,占位输出,并求和。
定义一个count=0,count为5的倍数时,换行。
注意:在输出连续数字的最后,不满5个,也有一个换行。

答案

#include 
#include 

using namespace std;

int main()
{
    int x,y; 
    cin >> x >> y;
    int i,j=0;
    int sum=0;

    for(i=x; i<=y; i++)
    {
        cout << setw(5) << i;
        j=j+1;
        if(j%5==0)
        {
            cout <<endl;
        }
        if(j%5!=0 && i==y)
        {
            cout <<endl;
        }
        sum=sum+i;
    }
    cout <<"Sum = " <<sum;
    return 0;
}

L1-009 N个数求和

本题的要求很简单,就是求N个数字的和。麻烦的是,这些数字是以有理数分子/分母的形式给出的,你输出的和也必须是有理数的形式。

输入格式:
输入第一行给出一个正整数N(≤100)。随后一行按格式a1/b1 a2/b2 …给出N个有理数。题目保证所有分子和分母都在长整型范围内。另外,负数的符号一定出现在分子前面。

输出格式:
输出上述数字和的最简形式 —— 即将结果写成整数部分 分数部分,其中分数部分写成分子/分母,要求分子小于分母,且它们没有公因子。如果结果的整数部分为0,则只输出分数部分。

输入样例1:

5
2/5 4/15 1/30 -2/60 8/3

输出样例1:

3 1/3

输入样例2:

2
4/3 2/3

输出样例2:

2

输入样例3:

3
1/3 -1/6 1/8

输出样例3:

7/24

大意


思路


答案

#include
#include
#include
#include

typedef long long ll;

ll gcd(ll x,ll y)
{
    return y ? gcd(y,x%y):x;
}

void OUTput(ll a,ll b) 
{
    ll e = a/b;
    a -= e*b;
    if(e == 0 && a == 0)
        printf("0");
    if(e != 0)
        printf("%lld",e);
    if(a != 0 && e!= 0)
        printf(" ");
    if(a != 0)
        printf("%lld/%lld",a,b);
    return;
}

int main()
{
    ll n;
    ll a,b,c,d;
    scanf("%lld",&n);
    scanf("%lld/%lld",&a,&b);
    for(int i=1;i<=n-1;i++)
    {
        scanf("%lld/%lld",&c,&d);
        ll g = gcd(b,d);
        ll mul = b/g*d; 
        ll e1 = mul/b; 
        ll e2 = mul/d; 
        a = a*e1 + c*e2; 
        b = mul;
        if(a != 0) 
        {
            ll gg = gcd(a,b);
            a /= gg;
            b /= gg;
        }
    }
    OUTput(a,b);
    return 0;
}

L1-010 比较大小

本题要求将输入的任意3个整数从小到大输出。

输入格式:
输入在一行中给出3个整数,其间以空格分隔。

输出格式:
在一行中将3个整数从小到大输出,其间以“->”相连。

输入样例:

4 2 8

输出样例:

2->4->8

大意

三个数作比较,中间加“->”后,顺序输出。

思路

数组存三个数,sort排序,输出。

答案

#include 

using namespace std;

int a[5];
int main()
{
    cin >> a[1] >> a[2] >> a[3];
    sort(a, a + 4);
    cout << a[1] << "->" << a[2] << "->" << a[3] << endl;
    return 0;
}

----------------------------------------------11~20----------------------------------------------

L1-011 A-B

本题要求你计算A−B。不过麻烦的是,A和B都是字符串 —— 即从字符串A中把字符串B所包含的字符全删掉,剩下的字符组成的就是字符串A−B。

输入格式:
输入在2行中先后给出字符串A和B。两字符串的长度都不超过10的4次方,并且保证每个字符串都是由可见的ASCII码和空白字符组成,最后以换行符结束。

输出格式:
在一行中打印出A−B的结果字符串。

输入样例:

I love GPLT!  It's a fun game!
aeiou

输出样例:

I lv GPLT!  It's  fn gm!

大意

有A、B两个字符串,从A中删去B里面的字符后,输出A串。

思路

定义两个字符串,双层遍历,外层A串,内层B串,逐个字符判断。
不符合条件输出。

答案

#include 
#include 

using namespace std;

int main()
{
    string s1;
    string s2;
    cin >> s1 >> s2;
    int l,k,i,j;
    int f;
    l=s1.length();
    k=s2.length();
    for(i=0;i<l;i++)
    {
        f=0;
        for(j=0;j<k;j++)
        {
           if(s1[i]==s2[j])
           {
               f=1;
           }
        }
        if(f==0)
        {
            cout <<s1[i];
        }
    }
    return 0;
}

L1-012 计算指数

真的没骗你,这道才是简单题 —— 对任意给定的不超过 10 的正整数 n,要求你输出 2 的n次方。不难吧?

输入格式:
输入在一行中给出一个不超过 10 的正整数 n。

输出格式:
在一行中按照格式 2^n = 计算结果 输出 2 的n次方的值。

输入样例:

5

输出样例:

2^5 = 32

大意

输入n,输出2的n次方的结果。

思路

遍历,n为几,循环几次后输出。

答案

#include 

using namespace std;

int main()
{
    int n;
    cin >> n;
    int i;
    int s=1;
    for(i=0; i<n; i++)
    {
        s=s*2;
    }
    cout << "2^"<< n <<" = "<<s << endl;
    return 0;
}

L1-013 计算阶乘和

对于给定的正整数N,需要你计算 S=1!+2!+3!+…+N!。

输入格式:
输入在一行中给出一个不超过10的正整数N。

输出格式:
在一行中输出S的值。

输入样例:

3

输出样例:

9

大意

输入n,从1阶乘加到n的阶乘,输出结果。

思路

n不超过10,直接存储1->10的阶乘。之后遍历相加,输出。 

答案

#include 

using namespace std;

int main()
{
    int s[10];
    s[0]=1;
    s[1]=2;
    s[2]=1*2*3;
    s[3]=1*2*3*4;
    s[4]=1*2*3*4*5;
    s[5]=1*2*3*4*5*6;
    s[6]=1*2*3*4*5*6*7;
    s[7]=1*2*3*4*5*6*7*8;
    s[8]=1*2*3*4*5*6*7*8*9;
    s[9]=1*2*3*4*5*6*7*8*9*10;
    int n,i,t=0;
    cin >>n;
    for(i=0;i<n;i++)
    {
        t=t+s[i];
    }
    cout << t << endl;
    return 0;
}

L1-014 简单题

这次真的没骗你 —— 这道超级简单的题目没有任何输入。

你只需要在一行中输出事实:This is a simple problem. 就可以了。

输入样例:

输出样例:

This is a simple problem.

大意

输出一句话:This is a simple problem.

思路

直接输出。

答案

#include 

using namespace std;

int main()
{
    cout << "This is a simple problem." << endl;
    return 0;
}

L1-015 跟奥巴马一起画方块

美国总统奥巴马不仅呼吁所有人都学习编程,甚至以身作则编写代码,成为美国历史上首位编写计算机代码的总统。2014年底,为庆祝“计算机科学教育周”正式启动,奥巴马编写了很简单的计算机代码:在屏幕上画一个正方形。现在你也跟他一起画吧!

输入格式:
输入在一行中给出正方形边长N(3≤N≤21)和组成正方形边的某种字符C,间隔一个空格。

输出格式:
输出由给定字符C画出的正方形。但是注意到行间距比列间距大,所以为了让结果看上去更像正方形,我们输出的行数实际上是列数的50%(四舍五入取整)。

输入样例:

10 a

输出样例:

aaaaaaaaaa
aaaaaaaaaa
aaaaaaaaaa
aaaaaaaaaa
aaaaaaaaaa

大意

输出特殊字母的正方形(其实是长方形),输入的数字是长。宽是长的一半(四舍五入)。

思路

确定宽度,长/2可以除尽,则商为宽,反之,则商加一为宽。
宽为外层循环,长为内层循环,遍历输出。

答案

#include 
#include 
using namespace std;

int main()
{
    int n;
    string x;
    cin >> n >> x;
    int l;
    int i, j;
    // 列长度
    if (n % 2 == 0)
    {
        l = n / 2;
    }
    if (n % 2 != 0)
    {
        l = n / 2 + 1;
    }
    // 打印
    for (i = 0; i < l; i++)
    {
        for (j = 0; j < n; j++)
        {
            cout << x;
        }
        cout << endl;
    }
    return 0;
}

L1-016 查验身份证

一个合法的身份证号码由17位地区、日期编号和顺序编号加1位校验码组成。校验码的计算规则如下:

首先对前17位数字加权求和,权重分配为:{7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};然后将计算的和对11取模得到值Z;最后按照以下关系对应Z值与校验码M的值:

Z:0 1 2 3 4 5 6 7 8 9 10
M:1 0 X 9 8 7 6 5 4 3 2
现在给定一些身份证号码,请你验证校验码的有效性,并输出有问题的号码。

输入格式:
输入第一行给出正整数N(≤100)是输入的身份证号码的个数。随后N行,每行给出1个18位身份证号码。

输出格式:
按照输入的顺序每行输出1个有问题的身份证号码。这里并不检验前17位是否合理,只检查前17位是否全为数字且最后1位校验码计算准确。如果所有号码都正常,则输出All passed。

输入样例1:

4
320124198808240056
12010X198901011234
110108196711301866
37070419881216001X

输出样例1:

12010X198901011234
110108196711301866
37070419881216001X

输入样例2:

2
320124198808240056
110108196711301862

输出样例2:

All passed

大意

身份证的第18位是   前17位数字权重求和,对11取余后的数字的  校验码。
1、检查前17为是否为数字(第二步的判断不对,就一定不是数字);
2、对比计算(答案错误了,不用判断条件1,直接false),观察第18位数字是否正确。

思路

存储为权重数组、校验码字符串、id字符串。
遍历一行一行计算、判断。
计算结果取余后为校验码,判断是否为该数据的第18位。
false输出,否则下一个。所有数据判断后,all还为true,则输出true

答案

#include 
#include 
#include 
#include 
#include 
#include 
using namespace std;

const int W[] = {7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};
const char M[] = "10X98765432";

int main()
{
    int N;
    bool all = true;

    cin >> N;
    for (int i = 0; i < N; i++)
    {
        char id[20];
        cin >> id;

        int z = 0;
        for (int i = 0; i < 17; i++)
        {
            z += W[i] * (id[i] - '0');
        }

        if (M[z % 11] != id[17])
        {
            cout << id << endl;
            all = false;
        }
    }

    if (all)
        cout << "All passed" << endl;
    return 0;
}

L1-017 到底有多二

一个整数“犯二的程度”定义为该数字中包含2的个数与其位数的比值。如果这个数是负数,则程度增加0.5倍;如果还是个偶数,则再增加1倍。例如数字-13142223336是个11位数,其中有3个2,并且是负数,也是偶数,则它的犯二程度计算为:3/11×1.5×2×100%,约为81.82%。本题就请你计算一个给定整数到底有多二。

输入格式:
输入第一行给出一个不超过50位的整数N。

输出格式:
在一行中输出N犯二的程度,保留小数点后两位。

输入样例:

-13142223336

输出样例:

81.82%

大意

输入数字,存为字符数组。
2的个数/数字位数(不带‘-’符号),
如果是负数,结果*1.5,如果偶数,继续*2。
结果以%百分数形式输出。

思路

遍历,算

答案

// c语言
#include
#include

int main(void)
{
    char N[50]; //定义不超过50位的整数
    int len, i, count = 0;
    double n; //n一定要是双精度
    scanf("%s", N);
    for (i = 0; N[i] != '\0'; i++) //统计2的个数
        if (N[i] == '2') count++;
    n = count*1.0/strlen(N)*1.0; //别忘记转换为浮点型
    if (N[0] == '-') {
        n = count*1.0/(strlen(N) - 1)*1.0; //负数位数要减一
        n *= 1.5; //乘1.5倍
    }
    if (N[strlen(N) - 1]%2 == 0) n *= 2; //若是偶数,乘2倍
    printf("%.2f%%", n*100);//百分号的转义字符%%
    return 0;
}

L1-018 大笨钟

微博上有个自称“大笨钟V”的家伙,每天敲钟催促码农们爱惜身体早点睡觉。不过由于笨钟自己作息也不是很规律,所以敲钟并不定时。一般敲钟的点数是根据敲钟时间而定的,如果正好在某个整点敲,那么“当”数就等于那个整点数;如果过了整点,就敲下一个整点数。另外,虽然一天有24小时,钟却是只在后半天敲1~12下。例如在23:00敲钟,就是“当当当当当当当当当当当”,而到了23:01就会是“当当当当当当当当当当当当”。在午夜00:00到中午12:00期间(端点时间包括在内),笨钟是不敲的。

下面就请你写个程序,根据当前时间替大笨钟敲钟。

输入格式:
输入第一行按照hh:mm的格式给出当前时间。其中hh是小时,在00到23之间;mm是分钟,在00到59之间。

输出格式:
根据当前时间替大笨钟敲钟,即在一行中输出相应数量个Dang。如果不是敲钟期,则输出:

Only hh:mm. Too early to Dang.
其中hh:mm是输入的时间。

输入样例1:

19:05

输出样例1:

DangDangDangDangDangDangDangDang

输入样例2:

07:05

输出样例2:

Only 07:05.  Too early to Dang.

大意


思路


答案

#include 
#include 

using namespace std;

int main()
{
    string s;
    cin >>s;
    //不响
    if(s[0]=='0')
    {
        cout <<"Only "<<s<<"."<<"  Too early to Dang."<<endl;
    }
    if(s[0]=='1' && ( s[1]=='1' || s[1]=='0') )
    {
        cout <<"Only "<<s<<"."<<"  Too early to Dang."<<endl;
    }
    if(s[0]=='1' && s[1]=='2' && s[3]=='0' && s[4]=='0')
    {
        cout <<"Only "<<s<<"."<<"  Too early to Dang."<<endl;
    }

    //响

    //1
    if(s[0]=='1' && s[1]=='2' && (s[3]!='0' || s[4]!='0'))
    {
        cout <<"Dang"<<endl;
    }
    if(s[0]=='1' && s[1]=='3' && s[3]=='0' && s[4]=='0')
    {
        cout <<"Dang"<<endl;
    }

    //2
    if(s[0]=='1' && s[1]=='3' && (s[3]!='0' || s[4]!='0'))
    {
        cout <<"DangDang"<<endl;
    }
    if(s[0]=='1' && s[1]=='4' && s[3]=='0' && s[4]=='0')
    {
        cout <<"DangDang"<<endl;
    }

    //3
    if(s[0]=='1' && s[1]=='4' && (s[3]!='0' || s[4]!='0'))
    {
        cout <<"DangDangDang"<<endl;
    }
    if(s[0]=='1' && s[1]=='5' && s[3]=='0' && s[4]=='0')
    {
        cout <<"DangDangDang"<<endl;
    }

    //4
    if(s[0]=='1' && s[1]=='5' && (s[3]!='0' || s[4]!='0'))
    {
        cout <<"DangDangDangDang"<<endl;
    }
    if(s[0]=='1' && s[1]=='6' && s[3]=='0' && s[4]=='0')
    {
        cout <<"DangDangDangDang"<<endl;
    }

    //5
    if(s[0]=='1' && s[1]=='6' && (s[3]!='0' || s[4]!='0'))
    {
        cout <<"DangDangDangDangDang"<<endl;
    }
    if(s[0]=='1' && s[1]=='7' && s[3]=='0' && s[4]=='0')
    {
        cout <<"DangDangDangDangDang"<<endl;
    }

    //6
    if(s[0]=='1' && s[1]=='7' && (s[3]!='0' || s[4]!='0'))
    {
        cout <<"DangDangDangDangDangDang"<<endl;
    }
    if(s[0]=='1' && s[1]=='8' && s[3]=='0' && s[4]=='0')
    {
        cout <<"DangDangDangDangDangDang"<<endl;
    }

    //7
    if(s[0]=='1' && s[1]=='8' && (s[3]!='0' || s[4]!='0'))
    {
        cout <<"DangDangDangDangDangDangDang"<<endl;
    }
    if(s[0]=='1' && s[1]=='9' && s[3]=='0' && s[4]=='0')
    {
        cout <<"DangDangDangDangDangDangDang"<<endl;
    }

    //8
    if(s[0]=='1' && s[1]=='9' && (s[3]!='0' || s[4]!='0'))
    {
        cout <<"DangDangDangDangDangDangDangDang"<<endl;
    }
    if(s[0]=='2' && s[1]=='0' && s[3]=='0' && s[4]=='0')
    {
        cout <<"DangDangDangDangDangDangDangDang"<<endl;
    }

    //9
    if(s[0]=='2' && s[1]=='0' && (s[3]!='0' || s[4]!='0') )
    {
        cout <<"DangDangDangDangDangDangDangDangDang"<<endl;
    }
     if(s[0]=='2' && s[1]=='1' && s[3]=='0' && s[4]=='0')
    {
        cout <<"DangDangDangDangDangDangDangDangDang"<<endl;
    }

    //10
    if(s[0]=='2' && s[1]=='1' && (s[3]!='0' || s[4]!='0'))
    {
        cout <<"DangDangDangDangDangDangDangDangDangDang"<<endl;
    }
     if(s[0]=='2' && s[1]=='2' && s[3]=='0' && s[4]=='0')
    {
        cout <<"DangDangDangDangDangDangDangDangDangDang"<<endl;
    }

    //11
    if(s[0]=='2' && s[1]=='2' && (s[3]!='0' || s[4]!='0'))
    {
        cout <<"DangDangDangDangDangDangDangDangDangDangDang"<<endl;
    }
     if(s[0]=='2' && s[1]=='3' && s[3]=='0' && s[4]=='0')
    {
        cout <<"DangDangDangDangDangDangDangDangDangDangDang"<<endl;
    }

    //12
    if(s[0]=='2' && s[1]=='3' && (s[3]!='0' || s[4]!='0'))
    {
        cout <<"DangDangDangDangDangDangDangDangDangDangDangDang"<<endl;
    }
    return 0;
}

L1-019 谁先倒

划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划出一个数字。如果谁比划出的数字正好等于两人喊出的数字之和,谁就输了,输家罚一杯酒。两人同赢或两人同输则继续下一轮,直到唯一的赢家出现。

下面给出甲、乙两人的酒量(最多能喝多少杯不倒)和划拳记录,请你判断两个人谁先倒。

输入格式:
输入第一行先后给出甲、乙两人的酒量(不超过100的非负整数),以空格分隔。下一行给出一个正整数N(≤100),随后N行,每行给出一轮划拳的记录,格式为:

甲喊 甲划 乙喊 乙划
其中喊是喊出的数字,划是划出的数字,均为不超过100的正整数(两只手一起划)。

输出格式:
在第一行中输出先倒下的那个人:A代表甲,B代表乙。第二行中输出没倒的那个人喝了多少杯。题目保证有一个人倒下。注意程序处理到有人倒下就终止,后面的数据不必处理。

输入样例:

1 1
6
8 10 9 12
5 10 5 10
3 8 5 12
12 18 1 13
4 16 12 15
15 1 1 16

输出样例:

A
1

大意


思路


答案

#include
#include
using namespace std;
int main()
{
    int x,y,n;
    cin>>x>>y>>n;
    int a,u,b,v;
    int tag1=0,tag2=0;
    int cnt1=0,cnt2=0;
    for(int i=0; i<n; i++)
    {
        cin>>a>>u>>b>>v;
        if(tag1==0&&tag2==0)
        {
            if(u==a+b)
                cnt1++; //甲输
            else if(v==a+b)
                cnt2++; //乙输
            if(cnt1 > x)
                tag1 = 1;
            if(cnt2 > y)
                tag2 = 1;
        }
    }
    if(tag1==1)
    {
        cout << "A" <<endl;
        cout <<cnt2<< endl;
    }
    if(tag2==1)
    {
        cout << "B" <<endl;
        cout <<cnt1<< endl;
    }
    return 0;
}

L1-020 帅到没朋友

当芸芸众生忙着在朋友圈中发照片的时候,总有一些人因为太帅而没有朋友。本题就要求你找出那些帅到没有朋友的人。

输入格式:
输入第一行给出一个正整数N(≤100),是已知朋友圈的个数;随后N行,每行首先给出一个正整数K(≤1000),为朋友圈中的人数,然后列出一个朋友圈内的所有人——为方便起见,每人对应一个ID号,为5位数字(从00000到99999),ID间以空格分隔;之后给出一个正整数M(≤10000),为待查询的人数;随后一行中列出M个待查询的ID,以空格分隔。

注意:没有朋友的人可以是根本没安装“朋友圈”,也可以是只有自己一个人在朋友圈的人。虽然有个别自恋狂会自己把自己反复加进朋友圈,但题目保证所有K超过1的朋友圈里都至少有2个不同的人。

输出格式:
按输入的顺序输出那些帅到没朋友的人。ID间用1个空格分隔,行的首尾不得有多余空格。如果没有人太帅,则输出No one is handsome。

注意:同一个人可以被查询多次,但只输出一次。

输入样例1:

3
3 11111 22222 55555
2 33333 44444
4 55555 66666 99999 77777
8
55555 44444 10000 88888 22222 11111 23333 88888

输出样例1:

10000 88888 23333

输入样例2:

3
3 11111 22222 55555
2 33333 44444
4 55555 66666 99999 77777
4
55555 44444 22222 11111

输出样例2:

No one is handsome

大意


思路


答案

#include 
#include 
int main(void) {
    int n , k , s , m , check = 0;
    int ant[100000] = {0};
    int i, j, d = 0, sum = 0;
    scanf("%d", &n);
    for (i = 0; i < n; i++) {
        scanf("%d", &k);
        if (k == 1) {
            scanf("%d", &s);
            continue;
        }
        for (j = 0; j < k; j++) {
            scanf("%d", &s);
            ant[s]++;
        }
    }
    scanf("%d", &m);
    for (i = 0; i < m; i++) {
        scanf("%d", &check);
        if (ant[check] == 0) {
            if (d == 0) {
                d++;
            } else {
                printf(" ");
            }
            printf("%05d", check);
            ant[check] = 1;
            sum++;
        }
    }
    if (sum == 0) {
        printf("No one is handsome");
    }
    return 0;
}

----------------------------------------------21~30----------------------------------------------

L1-021 重要的话说三遍

这道超级简单的题目没有任何输入。
你只需要把这句很重要的话 —— “I’m gonna WIN!”——连续输出三遍就可以了。
注意每遍占一行,除了每行的回车不能有任何多余字符。

输入样例:

输出样例:

I'm gonna WIN!
I'm gonna WIN!
I'm gonna WIN!

大意


思路


答案

#include

using namespace std;

int main()
{
   cout <<"I'm gonna WIN!"<<endl;
   cout <<"I'm gonna WIN!"<<endl;
   cout <<"I'm gonna WIN!"<<endl;
   return 0;
}

L1-022 奇偶分家

给定N个正整数,请统计奇数和偶数各有多少个?

输入格式:
输入第一行给出一个正整N(≤1000);第2行给出N个非负整数,以空格分隔。

输出格式:
在一行中先后输出奇数的个数、偶数的个数。中间以1个空格分隔。

输入样例:

9
88 74 101 26 15 0 34 22 77

输出样例:

3 6

大意


思路


答案

#include 

using namespace std;

int main() {
    int n;
    int arr[1050] = {0};
    // memset(arr, 0, sizeof(0));
    int i, d = 0, k = 0;

    cin >> n;
    for (i = 0; i < n; i++) {
        cin >> arr[i];
        if (arr[i] % 2 == 0) {
            d++;
        } else {
            k++;
        }
    }
    cout << k << " " << d << endl;
    return 0;
}

L1-023 输出GPLT

给定一个长度不超过10000的、仅由英文字母构成的字符串。请将字符重新调整顺序,按GPLTGPLT…这样的顺序输出,并忽略其它字符。当然,四种字符(不区分大小写)的个数不一定是一样多的,若某种字符已经输出完,则余下的字符仍按GPLT的顺序打印,直到所有字符都被输出。

输入格式:
输入在一行中给出一个长度不超过10000的、仅由英文字母构成的非空字符串。

输出格式:
在一行中按题目要求输出排序后的字符串。题目保证输出非空。

输入样例:

pcTclnGloRgLrtLhgljkLhGFauPewSKgt

输出样例:

GPLTGPLTGLTGLGLL

大意


思路


答案

#include 

using namespace std;

int main() {
    // 字母标记
    int a = 0, s = 0, d = 0, f = 0;
    int i;
    char str[10000];
    cin >> str;
    int len;
    len = strlen(str);
    for (i = 0; i < len; i++) {
        if (str[i] == 'g' || str[i] == 'G') {
            a++;
        }
        if (str[i] == 'p' || str[i] == 'P') {
            s++;
        }
        if (str[i] == 'l' || str[i] == 'L') {
            d++;
        }
        if (str[i] == 't' || str[i] == 'T') {
            f++;
        }
    }
    // cout << a << ' ' << s << ' ' << d << ' ' << f << endl;
    while (a != 0 || s != 0 || d != 0 || f != 0) {
        if (a != 0) {
            cout << 'G';
            a--;
        }
        if (s != 0) {
            cout << 'P';
            s--;
        }
        if (d != 0) {
            cout << 'L';
            d--;
        }
        if (f != 0) {
            cout << "T";
            f--;
        }
    }
    return 0;
}

L1-024 后天

如果今天是星期三,后天就是星期五;如果今天是星期六,后天就是星期一。我们用数字1到7对应星期一到星期日。给定某一天,请你输出那天的“后天”是星期几。

输入格式:
输入第一行给出一个正整数D(1 ≤ D ≤ 7),代表星期里的某一天。

输出格式:
在一行中输出D天的后天是星期几。

输入样例:

3

输出样例:

5

大意


思路


答案

// #include 
// using namespace std; 
 
// int main() 
// {
//     int n;
//     scanf("%d",&n);
//     int answer;
//     answer = ( n + 2 ) % 7;
//     if(answer == 0)
//     {
//     	answer = 7;
//     }
//     printf("%d",answer);
// 	return 0;
// }

#include 

using namespace std;

int main() {
    int n;
    cin >> n;
    int t;
    t = (n + 2) % 7;
    if (t == 0)
        t = 7;
    cout << t << endl;
    return 0;
}

L1-025 正整数A+B

题的目标很简单,就是求两个正整数A和B的和,其中A和B都在区间[1,1000]。稍微有点麻烦的是,输入并不保证是两个正整数。

输入格式:
输入在一行给出A和B,其间以空格分开。问题是A和B不一定是满足要求的正整数,有时候可能是超出范围的数字、负数、带小数点的实数、甚至是一堆乱码。

注意:我们把输入中出现的第1个空格认为是A和B的分隔。题目保证至少存在一个空格,并且B不是一个空字符串。

输出格式:
如果输入的确是两个正整数,则按格式A + B = 和输出。如果某个输入不合要求,则在相应位置输出?,显然此时和也是?。

输入样例1:

123 456

输出样例1:

123 + 456 = 579

输入样例2:

22. 18

输出样例2:

? + 18 = ?

输入样例3:

-100 blabla bla...33

输出样例3:

? + ? = ?

大意


思路


答案

#include 
using namespace std;

int check(char* s)  // 判断是否是正整数,是则返回num,不是则返回-1
{
    int sum = 0;
    for (int i = 0; i < strlen(s); i++) {
        if (s[i] >= '0' && s[i] <= '9')
            // 数字*10 是进制(遍历的是每一位数)
            sum = sum * 10 + s[i] - '0';
        else
            return -1;
    }
    if (sum >= 1 && sum <= 1000)
        return sum;
    else
        return -1;
}
int main() {
    char a[10000], b[10000];  // 录入A和B
    cin >> a;
    getchar();
    cin.getline(b, 10000);
    int p, q;
    p = check(a);
    q = check(b);
    if (p == -1 and q == -1)
        cout << "? + ? = ?";
    else if (p == -1)
        cout << "? + " << q << " = ?";
    else if (q == -1)
        cout << p << " + ? = ?";
    else
        cout << p << " + " << q << " = " << p + q;
    return 0;
}

L1-026 I Love GPLT

这道超级简单的题目没有任何输入。
你只需要把这句很重要的话 —— “I Love GPLT”——竖着输出就可以了。
所谓“竖着输出”,是指每个字符占一行(包括空格),即每行只能有1个字符和回车。
输入样例:

输出样例:

I
 
L
o
v
e
 
G
P
L
T

大意


思路


答案

#include 
#include 
int main() {
    char a[] = "I Love GPLT";
    int m = strlen(a);
    for (int i = 0; i < m; i++)
        printf("%c\n", a[i]);
}

L1-027 出租

其实这段代码很简单,index数组就是arr数组的下标,index[0]=2 对应 arr[2]=1,index[1]=0 对应 arr[0]=8,index[2]=3 对应 arr[3]=0,以此类推…… 很容易得到电话号码是18013820100。

本题要求你编写一个程序,为任何一个电话号码生成这段代码 —— 事实上,只要生成最前面两行就可以了,后面内容是不变的。

输入格式:
输入在一行中给出一个由11位数字组成的手机号码。

输出格式:
为输入的号码生成代码的前两行,其中arr中的数字必须按递减顺序给出。

输入样例:

18013820100

输出样例:

int[] arr = new int[]{8,3,2,1,0};
int[] index = new int[]{3,0,4,3,1,0,2,4,3,4,4};

大意


思路


答案

#include 

using namespace std;

int main() {
    string str1;
    int len1, arr[10] = {0};
    // int ant[20] = {0};
    int count = 1;
    cin >> str1;
    len1 = str1.length();
    int i = 0, t = 0;
    for (i = 0; i < len1; i++) {
        t = str1[i] - 48;
        // cout << t << endl;
        arr[t] = 1;
    }

    for (i = 9; i >= 0; i--) {
        if (arr[i] == 1) {
            arr[i] = count;
            count += 1;
        }
    }
    // for (i = 0; i < 10; i++) {
    //     cout << arr[i] << endl;
    // }
    // cout << count << endl;
    // 输出
    int gg = 0;
    cout << "int[] arr = new int[]{";
    for (int i = 9; i >= 0; i--) {
        if (arr[i] > 0) {
            cout << i;
            gg += 1;
            if (gg < count - 1)
                cout << ",";
        }
    }
    cout << "};" << endl;

    cout << "int[] index = new int[]{";
    for (int i = 0; i < 11; i++) {
        t = str1[i] - 48;
        for (int j = 0; j < 10; j++) {
            if (j == t) {
                cout << arr[j] - 1;
                if (i < 10)
                    cout << ",";
            }
        }
    }
    cout << "};" << endl;

    return 0;
}

L1-028 判断素数

本题的目标很简单,就是判断一个给定的正整数是否素数。

输入格式:
输入在第一行给出一个正整数N(≤ 10),随后N行,每行给出一个小于2
31
的需要判断的正整数。

输出格式:
对每个需要判断的正整数,如果它是素数,则在一行中输出Yes,否则输出No。

输入样例:

2
11
111

输出样例:

Yes
No

大意


思路


答案

#include 

using namespace std;

int main() {
    int n;
    cin >> n;
    while (n--) {
        int t;
        cin >> t;
        int i = 0, f = 1;
        for (i = 2; i <= sqrt(t); i++) {
            if (t % i == 0) {
                f = 0;
                break;
            }
        }
        if (t == 1 || f == 0) {
            cout << "No" << endl;
        } else {
            cout << "Yes" << endl;
        }
    }
    return 0;
}

L1-029 是不是太胖了

据说一个人的标准体重应该是其身高(单位:厘米)减去100、再乘以0.9所得到的公斤数。已知市斤的数值是公斤数值的两倍。现给定某人身高,请你计算其标准体重应该是多少?(顺便也悄悄给自己算一下吧……)

输入格式:
输入第一行给出一个正整数H(100 < H ≤ 300),为某人身高。

输出格式:
在一行中输出对应的标准体重,单位为市斤,保留小数点后1位。

输入样例:

169

输出样例:

124.2

大意


思路


答案

#include 

using namespace std;

int main() {
    int h;
    cin >> h;
    if (h <= 100 || h > 300)
        return 0;

    float t;
    t = (h - 100) * 0.9 * 2;
    // cout.precision(1);  // 用这个来改变默认保留几位小数
    cout << setiosflags(ios::fixed);
    cout << setprecision(1) << t << endl;
    return 0;
}

L1-030 一帮一

“一帮一学习小组”是中小学中常见的学习组织方式,老师把学习成绩靠前的学生跟学习成绩靠后的学生排在一组。本题就请你编写程序帮助老师自动完成这个分配工作,即在得到全班学生的排名后,在当前尚未分组的学生中,将名次最靠前的学生与名次最靠后的异性学生分为一组。

输入格式:
输入第一行给出正偶数N(≤50),即全班学生的人数。此后N行,按照名次从高到低的顺序给出每个学生的性别(0代表女生,1代表男生)和姓名(不超过8个英文字母的非空字符串),其间以1个空格分隔。这里保证本班男女比例是1:1,并且没有并列名次。

输出格式:
每行输出一组两个学生的姓名,其间以1个空格分隔。名次高的学生在前,名次低的学生在后。小组的输出顺序按照前面学生的名次从高到低排列。

输入样例:

8
0 Amy
1 Tom
1 Bill
0 Cindy
0 Maya
1 John
1 Jack
0 Linda

输出样例:

Amy Jack
Tom Linda
Bill Maya
Cindy John

大意


思路


答案

// #include
// int main()
// {
// 	int N;				//表示全班总人数
// 	int sex[50];		//性别
// 	char name[50][15];	//姓名
// 	int i,j,k;			//用于循环
// 	scanf("%d",&N);
// 	if(N<=0 || N>50 ||N%2!=0)	return 0;	//正偶数,在1~50之间
// 	for(i=0;i
// 		scanf("%d %s",&sex[i],&name[i][0]);
// 	for(i=0;i
// 	{
// 		for(j=i;j==i;j++)	//控制从高名次开始往下查找,以高名次
// 		{
// 			for(k=N-1;k>=N/2;k--)	//控制从低往高查找,因为一共8人,所以下面最多4个与上面4个对应,只用循环4次即可
// 			{
// 				if(sex[j]!=sex[k]&&sex[j]<=1&&sex[k]<=1)
// 				{
// 					sex[j]=10;		//因为男生是1,女生是0,这里随便配上一个数10以后,搭配上面的逻辑判断就能排除掉已经选中人
// 					sex[k]=10;		//因为男生是1,女生是0,这里随便配上一个数10以后,搭配上面的逻辑判断就能排除掉已经选中人
// 					printf("%s %s\n",name[i],name[k]);
// 					break;
// 				}
// 			}
// 		}
// 	}
// }


#include 

using namespace std;

int main() {
    int n;
    cin >> n;
    struct {
        int a;
        string b;
    } stu[n];

    for (int i = 0; i < n; i++) {
        cin >> stu[i].a >> stu[i].b;
    }

    for (int i = 0, j = n - 1; i < j;) {
        if (stu[i].a != stu[j].a && stu[j].a != 3) {
            cout << stu[i].b << " " << stu[j].b << endl;
            stu[j].a = 3;
            i++;
            j = n - 1;
        } else {
            j--;
        }
    }

    return 0;
}

----------------------------------------------31~40----------------------------------------------

L1-031 到底是不是太胖了

据说一个人的标准体重应该是其身高(单位:厘米)减去100、再乘以0.9所得到的公斤数。真实体重与标准体重误差在10%以内都是完美身材(即 | 真实体重 − 标准体重 | < 标准体重×10%)。已知市斤是公斤的两倍。现给定一群人的身高和实际体重,请你告诉他们是否太胖或太瘦了。

输入格式:
输入第一行给出一个正整数N(≤ 20)。随后N行,每行给出两个整数,分别是一个人的身高H(120 < H < 200;单位:厘米)和真实体重W(50 < W ≤ 300;单位:市斤),其间以空格分隔。

输出格式:
为每个人输出一行结论:如果是完美身材,输出You are wan mei!;如果太胖了,输出You are tai pang le!;否则输出You are tai shou le!。

输入样例:

3
169 136
150 81
178 155

输出样例:

You are wan mei!
You are tai shou le!
You are tai pang le!

大意


思路


答案

#include 

using namespace std;

int main() {
    int n;
    cin >> n;
    while (n--) {
        int h;
        float t;
        cin >> h >> t;
        float st;
        st = (h - 100) * 0.9 * 2;
        if (abs(t - st) < st * 0.1) {
            cout << "You are wan mei!" << endl;
        }
        // (abs(b-c)>=(c*0.1))&&b>c
        if (abs(t - st) >= (st * 0.1) && t > st) {
            cout << "You are tai pang le!" << endl;
        }
        // (abs(b-c)>=(c*0.1))&&b
        if (abs(t - st) >= (st * 0.1) && t < st) {
            cout << "You are tai shou le!" << endl;
        }
    }
    return 0;
}

L1-032 Left-pad

根据新浪微博上的消息,有一位开发者不满NPM(Node Package Manager)的做法,收回了自己的开源代码,其中包括一个叫left-pad的模块,就是这个模块把javascript里面的React/Babel干瘫痪了。这是个什么样的模块?就是在字符串前填充一些东西到一定的长度。例如用去填充字符串GPLT,使之长度为10,调用left-pad的结果就应该是*****GPLT。Node社区曾经对left-pad紧急发布了一个替代,被严重吐槽。下面就请你来实现一下这个模块。

输入格式:
输入在第一行给出一个正整数N(≤10
4
)和一个字符,分别是填充结果字符串的长度和用于填充的字符,中间以1个空格分开。第二行给出原始的非空字符串,以回车结束。

输出格式:
在一行中输出结果字符串。

输入样例1:

15 _
I love GPLT

输出样例1:

____I love GPLT

输入样例2:

4 *
this is a sample for cut

输出样例2:

 cut

大意


思路


答案

// #include 

// using namespace std;

// int main() {
//     int n;
//     char c;
//     string str1;
//     cin >> n >> c;
//     getchar();
//     getline(cin, str1);
//     int len;
//     len = str1.size();
//     // cout << len;
//     // for (int i = 0; i < len; i++) {
//     //     cout << str1[i];
//     // }
//     if (len == n) {
//         cout << str1 << endl;
//     } else if (len < n) {
//         for (int i = n - len; i > 0; i--) {
//             cout << c;
//         }
//         cout << str1 << endl;
//     } else {
//         int i = len - n;
//         // cout << len << n << i;
//         for (i; n > 0; n--) {
//             cout << str1[i];
//             i++;
//         }
//     }

//     return 0;
// }


#include 

using namespace std;

int main() {
    int n;
    char c;
    string str1;
    cin >> n >> c;
    getchar();
    getline(cin, str1);
    int len;
    len = str1.size();
    // cout << len;
    // for (int i = 0; i < len; i++) {
    //     cout << str1[i];
    // }
    if (len == n) {
        cout << str1 << endl;
    } else if (len < n) {
        for (int i = n - len; i > 0; i--) {
            cout << c;
        }
        cout << str1 << endl;
    } else {
        for (int i = len - n; i<len; i++) {
            cout << str1[i];
        }
    }

    return 0;
}

L1-033 出生年

以上是新浪微博中一奇葩贴:“我出生于1988年,直到25岁才遇到4个数字都不相同的年份。”也就是说,直到2013年才达到“4个数字都不相同”的要求。本题请你根据要求,自动填充“我出生于y年,直到x岁才遇到n个数字都不相同的年份”这句话。

输入格式:
输入在一行中给出出生年份y和目标年份中不同数字的个数n,其中y在[1, 3000]之间,n可以是2、或3、或4。注意不足4位的年份要在前面补零,例如公元1年被认为是0001年,有2个不同的数字0和1。

输出格式:
根据输入,输出x和能达到要求的年份。数字间以1个空格分隔,行首尾不得有多余空格。年份要按4位输出。注意:所谓“n个数字都不相同”是指不同的数字正好是n个。如“2013”被视为满足“4位数字都不同”的条件,但不被视为满足2位或3位数字不同的条件。

输入样例1:

1988 4

输出样例1:

25 2013

输入样例2:

1 2

输出样例2:

0 0001

大意


思路


答案

#include 

using namespace std;

int different(int n1, int n) {
    int arr[10] = {0};
    arr[n1 % 10] = 1;
    arr[n1 / 10 % 10] = 1;
    arr[n1 / 100 % 10] = 1;
    arr[n1 / 1000] = 1;
    int count = 0;
    for (int i = 0; i < 10; i++) {
        if (arr[i] == 1) {
            count++;
        }
    }
    if (count != n) {
        n1++;
        different(n1, n);
    }
    if (count == n){
        return n1;
    }
}

int main() {
    int n1;
    int n;
    cin >> n1 >> n;
    int n2;  // 输出年份
    // age = n2-n1 年龄
    int age = 0;
    n2 = different(n1, n);
    age = n2 - n1;
    cout << age << " " << setw(4) << setfill('0') << n2 << endl;
    return 0;
}

----------------------------------------------41~50----------------------------------------------

你可能感兴趣的:(c/c++学习,c++,c语言)