L1-3. 个位数统计
给定一个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. 打印沙漏
本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定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. 考试座位号
每个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. 念数字
输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出“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. 求整数段和
给定两个整数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;
}