题目十八
题目
微博上有个自称“大笨钟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.
链接
L1-018 大笨钟 - 团体程序设计天梯赛-练习集 (pintia.cn)
代码
#include<bits/stdc++.h>
using namespace std;
int main()
{
int hh,mm;
scanf("%02d:%02d",&hh,&mm);
if(hh>=0&&hh<12)
{
printf("Only %02d:%02d. Too early to Dang.",hh,mm);
}
else if(hh==12&&mm==0)
{
printf("Only %02d:%02d. Too early to Dang.",hh,mm);
}
else
{
for(int i=13;i<=hh;i++)
{
cout<<"Dang";
}
if(mm>0)
{
printf("Dang");
}
}
return 0;
}
题目十九
题目
给定一个长度不超过10000的、仅由英文字母构成的字符串。请将字符重新调整顺序,按GPLTGPLT....
这样的顺序输出,并忽略其它字符。当然,四种字符(不区分大小写)的个数不一定是一样多的,若某种字符已经输出完,则余下的字符仍按GPLT
的顺序打印,直到所有字符都被输出。
输入格式:
输入在一行中给出一个长度不超过10000的、仅由英文字母构成的非空字符串。
输出格式:
在一行中按题目要求输出排序后的字符串。题目保证输出非空。
输入样例:
pcTclnGloRgLrtLhgljkLhGFauPewSKgt
输出样例:
GPLTGPLTGLTGLGLL
链接
L1-023 输出GPLT - 团体程序设计天梯赛-练习集 (pintia.cn)
代码
#include<iostream>
#include<string>
using namespace std;
int main()
{
string a;
int i,b[4]={0,0,0,0};
getline(cin,a);
for(i=0;i<a.length();i++)
{
if(a[i]=='g'||a[i]=='G')
b[0]++;
else if(a[i]=='p'||a[i]=='P')
b[1]++;
else if(a[i]=='l'||a[i]=='L')
b[2]++;
else if(a[i]=='t'||a[i]=='T')
b[3]++;
}
while(b[0]+b[1]+b[2]+b[3])
{
if(b[0]>0)
{
printf("G");
b[0]--;
}
if(b[1]>0)
{
printf("P");
b[1]--;
}
if(b[2]>0)
{
printf("L");
b[2]--;
}
if(b[3]>0)
{
printf("T");
b[3]--;
}
}
return 0;
}