文章目录
-
- 2096、小明A+B
- 2097、Sky数[十进制、十二进制、十六进制各位之和是否相等]
- 2098、分拆素数和
- 2099、整除的尾数
- 2101、A + B Problem Too
- 2103、Family planning
- 2106、decimal system[多种数制表示的数相加]
- 2107、Founding of HDU[简单的排序]
- 2109、Fighting for HDU[擂台]
- 2113、Secret Number[各个位上为偶数的和]
2096、小明A+B
小明今年3岁了, 现在他已经能够认识100以内的非负整数, 并且能够进行100以内的非负整数的加法计算.
对于大于等于100的整数, 小明仅保留该数的最后两位进行计算, 如果计算结果大于等于100, 那么小明也仅保留计算结果的最后两位.
例如, 对于小明来说:
- 1234和34是相等的
- 35+80=15
给定非负整数A和B, 你的任务是代表小明计算出A+B的值.
Input
输入数据的第一行为一个正整数T, 表示测试数据的组数. 然后是T组测试数据. 每组测试数据包含两个非负整数A和B(A和B均在int型可表示的范围内).
Output
对于每组测试数据, 输出小明A+B的结果.
Sample Input
2
35 80
15 1152
Sample Output
15
67
Code
#include<iostream>
using namespace std;int f(int n){
int gewei=n%10;int shiwei=n/10%10;return gewei+shiwei*10;
}
int main(){
int t;cin>>t;while(t--){
int a,b;cin>>a>>b;if(a>=100){
//取a的个位和十位数 a=f(a);}else if(b>=100){
b=f(b);}int sum=a+b;if(sum>=100){
sum=f(sum);} cout<<sum<<endl;}return 0;
}
2097、Sky数[十进制、十二进制、十六进制各位之和是否相等]
Sky从小喜欢奇特的东西,而且天生对数字特别敏感,一次偶然的机会,他发现了一个有趣的四位数2992,这个数,它的十进制数表示,其四位数字之和为2+9+9+2=22,它的十六进制数BB0,其四位数字之和也为22,同时它的十二进制数表示1894,其四位数字之和也为22,啊哈,真是巧啊。Sky非常喜欢这种四位数,由于他的发现,所以这里我们命名其为Sky数。但是要判断这样的数还是有点麻烦啊,那么现在请你帮忙来判断任何一个十进制的四位数,是不是Sky数吧。
Input
输入含有一些四位正整数,如果为0,则输入结束。
Output
若n为Sky数,则输出“#n is a Sky Number.”,否则输出“#n is not a Sky Number.”。每个结果占一行。注意:#n表示所读入的n值。
Sample Input
2992
1234
0
Sample Output
2992 is a Sky Number.
1234 is not a Sky Number.
Code
/* 判断任意一个所给的四位数,其十进制数,十六进制数,是二进制数的各位之和是否相等 */
#include<iostream>
using namespace std;
int main(){
int n;while(cin>>n){
if(n==0) return 0;int sum1=0,temp;//计算十进制数表示的n的个位数字之和sum1int m=n;while(m!=0){
temp=m%10;sum1=sum1+temp;m=m/10;}//将十进制数n转化为十六进制数各位数字之和sum2int a=n,sum2=0;while(a!=0){
temp=a%16;sum2+=temp;a=a/16;} //将十进制数n转化为十二进制数各位数字之和sum3int c=n,sum3=0;while(c!=0){
temp=c%12;sum3+=temp;c=c/12;} if(sum1==sum2&&sum2==sum3){
cout<<n<<" is a Sky Number."<<endl;}else{
cout<<n<<" is not a Sky Number."<<endl;}}return 0;
}
2098、分拆素数和
把一个偶数拆成两个不同素数的和,有几种拆法呢?
Input
输入包含一些正的偶数,其值不会超过10000,个数不会超过500,若遇0,则结束。
Output
对应每个偶数,输出其拆成不同素数的个数,每个结果占一行。
Sample Input
30
26
0
Sample Output
3
2
Code:
//输入一个偶数,输出其能拆分成几个素数之和
#include<iostream>
using namespace std;
//判断一个数是否为素数
bool isPrime(int n){
for(int i=2;i<=n/2;i++){
if(n%i==0){
return false;}}return true;
} int main(){
int n;while(cin>>n){
if(n==0) return 0;int count=0;for(int i=2;i<=n/2;i++){
int a=n-i;if(a!=i&&isPrime(i)==true&&isPrime(a)==true){
count++;}}cout<<count<<endl;}return 0;
}
2099、整除的尾数
一个整数,只知道前几位,不知道末二位,被另一个整数除尽了,那么该数的末二位该是什么呢?
Input
输入数据有若干组,每组数据包含二个整数a,b(0<a<10000, 10<b<100),若遇到0 0则处理结束。
Output
对应每组数据,将满足条件的所有尾数在一行内输出,格式见样本输出。同组数据的输出,其每个尾数之间空一格,行末没有空格。
Sample Input
200 40
1992 95
0 0
Sample Output
00 40 80
15
Code
#include<iostream>
using namespace std;
int main(){
int a,b,flag;while(cin>>a>>b){
if(a==0&&b==0) return 0;flag=0; for(int i=0;i<=9;i++){
for(int j=0;j<=9;j++){
if((a*100+i*10+j)%b==0){
//a后面拼接两位数 if(flag==0){
cout<<i<<j;flag=1;}elsecout<<" "<<i<<j;}}}cout<<endl;}
}
2101、A + B Problem Too
This problem is also a A + B problem,but it has a little difference,you should determine does (a+b) could be divided with 86.For example ,if (A+B)=98,you should output no for result.
Input
Each line will contain two integers A and B. Process to end of file.
Output
For each case, if(A+B)%86=0,output yes in one line,else output no in one line.
Sample Input
1 1
8600 8600
Sample Output
no
yes
Code
//判断A+B能否被86整除
#include<iostream>
using namespace std;
int main(){
int a,b;while(cin>>a>>b){
if((a+b)%86==0){
cout<<"yes"<<endl;}else{
cout<<"no"<<endl;}}return 0;
}
2103、Family planning
As far as we known,there are so many people in this world,expecially in china.But many people like LJ always insist on that more people more power.And he often says he will burn as much babies as he could.Unfortunatly,the president XiaoHu already found LJ’s extreme mind,so he have to publish a policy to control the population from keep on growing.According the fact that there are much more men than women,and some parents are rich and well educated,so the president XiaoHu made a family planning policy:
According to every parents conditions to establish a number M which means that parents can born M children at most.But once borned a boy them can’t born other babies any more.If anyone break the policy will punished for 10000RMB for the first time ,and twice for the next time.For example,if LJ only allowed to born 3 babies at most,but his first baby is a boy ,but he keep on borning another 3 babies, so he will be punished for 70000RMB(10000+20000+40000) totaly.
Input
The first line of the input contains an integer T(1 <= T <= 100) which means the number of test cases.In every case first input two integers M(0<=M<=30) and N(0<=N<=30),N represent the number of babies a couple borned,then in the follow line are N binary numbers,0 represent girl,and 1 represent boy.
Output
Foreach test case you should output the total money a couple have to pay for their babies.
Sample Input
2
2 5
0 0 1 1 12 2
0 0
Sample Output
70000 RMB
0 RMB
Code:
题目:规定一对夫妇最多可以生M个孩子,并且若该夫妇已经生了男孩了,则不可以再生孩子,第一次超生孩子会罚款1万元
以后每次罚款会翻倍。则给定某夫妇可以生孩子的数量,以及该夫妇已经生下的孩子数量,问该夫妇需要交多少罚款
/* 题目:规定一对夫妇最多可以生M个孩子,并且若该夫妇已经生了男孩了,则不可以再生孩子,第一次超生孩子会罚款1万元 以后每次罚款会翻倍。则给定某夫妇可以生孩子的数量,以及该夫妇已经生下的孩子数量,问该夫妇需要交多少罚款 */
#include<iostream>
#include<cmath>
using namespace std;
int main(){
int t;cin>>t;while(t--){
//数据要用__int64,否则会WA __int64 m,n;//m代表应该要生孩子的数量,n代表已经生下的孩子的数量cin>>m>>n;int sex;//0代表女孩,1代表男孩__int64 punish=0;int flag=0,k=0;for(int i=1;i<=n;i++){
cin>>sex;if(i<=m&&sex==0){
continue;}else if(i<=m&&sex==1){
m=i;//生过男孩之后,以后再生孩子就要被处罚金 }else{
punish=punish+10000*pow(2,k);k++;}}if(n==0)cout<<punish<<" RMB"<<endl;elsecout<<punish<<" RMB"<<endl; }
}
2106、decimal system[多种数制表示的数相加]
As we know , we always use the decimal system in our common life, even using the computer. If we want to calculate the value that 3 plus 9, we just import 3 and 9.after calculation of computer, we will get the result of 12.
But after learning <>,we know that the computer will do the calculation as the following steps:
1 computer change the 3 into binary formality like 11;
2 computer change the 9 into binary formality like 1001;
3 computer plus the two number and get the result 1100;
4 computer change the result into decimal formality like 12;
5 computer export the result;
In the computer system there are other formalities to deal with the number such as hexadecimal. Now I will give several number with a kind of change method, for example, if I give you 1011(2), it means 1011 is a number in the binary system, and 123(10) means 123 if a number in the decimal system. Now I will give you some numbers with any kind of system, you guys should tell me the sum of the number in the decimal system.
Input
There will be several cases. The first line of each case contains one integers N, and N means there will be N numbers to import, then there will be N numbers at the next N lines, each line contains a number with such form : X1….Xn.(Y), and 0<=Xi<Y, 1<Y<=10. I promise you that the sum will not exceed the 100000000, and there will be at most 100 cases and the 0<N<=1000.
Output
There is only one line output case for each input case, which is the sum of all the number. The sum must be expressed using the decimal system.
Sample Input
3
1(2)
2(3)
3(4)4
11(10)
11(2)
11(3)
11(4)
Sample Output
6
23
Code
题目含义:计算多种数制的数相加所得的结果,以十进制的形式表现出来
//计算多种数制的数相加所得的结果
#include<iostream>
#include<stdlib.h>
#include<string>
#include<cmath>
using namespace std;//将b进制的数a转化为10进制
int convert_ten(int a,int b){
if(b==10) return a;int temp,i=0,result=0;while(a!=0){
temp=a%10;result=result+temp*pow(b,i);i++;a=a/10;}return result;
}int main(){
int n;string s,str;while(cin>>n){
getline(cin,str);int sum=0;for(int i=0;i<n;i++){
getline(cin,s);string s1=s.substr(0,s.find('('));string s2=s.substr(s.find('(')+1,s.find(')')-s.find('(')-1);int a=atoi(s1.c_str());int b=atoi(s2.c_str());//将b进制的数a转化为10进制数 b[2,10] sum+=convert_ten(a,b);} cout<<sum<<endl;}}
2107、Founding of HDU[简单的排序]
经过慎重的考虑,XHD,8600, LL,Linle以及RPG等ACM队员集体退役,甚至正在酝酿退学。
为什么?要考研?那也不用退学呀…
当然不是!真正的原因是他们想提前创业,想合伙成立一家公司,据说公司的名称都想好了,为了感谢多年的ACM集训队队长XHD,公司就叫海东集团(HaiDong Union),简称HDU.(对于这个公司名称,几个人私下里开玩笑说,外面的人看到HDU,可别以为是”胡捣集团”,呵呵)
公司成立了,谁来做老大呢?这对于合伙的公司可是一个难题。好在几位同学经过几年的ACM训练,思维非常活跃,马上想到推选AC战斗力最强的一位来做老总。
现在的问题就是,假设每人的AC战斗力是一个已知的整数,请编程输出最后选出的老总的AC战斗力。
Input
输入包含多组测试数据,每组数据占2行,首先一行是一个整数n(n<100),表示创立公司的人数,然后一行是n个32位整数,表示n个人的AC战斗力,n为0的时候结束输入。
Output
对于每个测试实例,请输出老总的AC战斗力,每个实例的输出占一行。
Sample Input
3
1 2 3
0
Sample Output
3
Code:
#include<iostream>
#include<algorithm>
using namespace std;
int main(){
int n,num[100];while(cin>>n){
if(n==0) return 0;int i;for(i=0;i<n;i++){
cin>>num[i];}sort(num,num+i);cout<<num[i-1]<<endl;}return 0;
}
2109、Fighting for HDU[擂台]
中日擂台赛
他们提出的比赛规则是这样的:
1 每方派出n个人参赛;
2. 出赛的顺序必须是从弱到强(主要担心中国人擅长的田忌赛马);
3. 每赢一场,得两分,打平得一分,否则得0分。
Input
输入包含多组测试数据,每组数据占3行,首先一行是一个整数n(n<100),表示每方上场队员的人数,接着的二行每行包含n个整数,分别依次表示中日两方人员的能力值,n为0的时候结束输入。
Output
对于每个测试实例,请输出比赛的结果,结果的格式如样例所示(数字和vs之间有且仅有一个空格),其中,HDU的比分在前。
每个实例的输出占一行。
Sample Input
3
5 2 6
1 3 4
0
Sample Output
6 vs 0
Code
//擂台比赛 思路:两个数组排序后,依次进行比较
#include<iostream>
#include<algorithm>
using namespace std;
int main(){
int n;while(cin>>n){
if(n==0) return 0;int group1[100],group2[100];for(int i=0;i<n;i++){
cin>>group1[i];}sort(group1,group1+n);for(int i=0;i<n;i++){
cin>>group2[i];}sort(group2,group2+n);//计算比分 int score1=0,score2=0;for(int i=0;i<n;i++){
if(group1[i]>group2[i]){
score1+=2;}else if(group1[i]==group2[i]){
score1+=1;score2+=1;}else{
score2+=2;} }cout<<score1<<" vs "<<score2<<endl; }}
2113、Secret Number[各个位上为偶数的和]
有一天, KIKI 收到一张奇怪的信, 信上要KIKI 计算出给定数各个位上数字为偶数的和.
eg. 5548
结果为12 , 等于 4 + 8
KIKI 很苦恼. 想请你帮忙解决这个问题.
Input
输入数据有多组,每组占一行,只有一个数字,保证数字在INT范围内.
Output
对于每组输入数据,输出一行,每两组数据之间有一个空行.
Sample Input
415326
3262
Sample Output
1210
Code
//对于输入的数据,输出各个位上为偶数的和
#include<iostream>
using namespace std;
int main(){
int n,num=0;while(cin>>n){
//将n的各位数表示出来int temp,sum=0;while(n!=0){
temp=n%10;if(temp%2==0){
sum+=temp;}n=n/10;}num++;if(num==1)cout<<sum<<endl;else{
cout<<endl;cout<<sum<<endl;} }return 0;
}