杭电ACM基础题(2096、2097、2098、2099、2101、2103、2106、2107、2109、2113)

2096、小明A+B

小明今年3岁了, 现在他已经能够认识100以内的非负整数, 并且能够进行100以内的非负整数的加法计算.
对于大于等于100的整数, 小明仅保留该数的最后两位进行计算, 如果计算结果大于等于100, 那么小明也仅保留计算结果的最后两位.

例如, 对于小明来说:

  1. 1234和34是相等的
  2. 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<

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值