文章目录
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的个位数字之和sum1
int m=n;
while(m!=0){
temp=m%10;
sum1=sum1+temp;
m=m/10;
}
//将十进制数n转化为十六进制数各位数字之和sum2
int a=n,sum2=0;
while(a!=0){
temp=a%16;
sum2+=temp;
a=a/16;
}
//将十进制数n转化为十二进制数各位数字之和sum3
int 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<