进制转换

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2057

题目求的是十六进制的加法。刚开始想的是把十六进制转化为十进制,进行加法运算后,再转化为十六进制。

所以这题可以直接用十六进制输入,然后进行十六进制的运算(其实不管是什么进制,在计算机中都是以二进制来计算的,只是按输入输出的格式不同,而强制转化为其它的进制),就像十进制的加法一样。

这里要注意的是输入小于15位,结果超过了二进制中的32位而小于64位。所以这里用__int64的类型。输入输入出格式就是(%I64x,%I64X)。由于%I64X,不能输出负数,所以负数的输出要做处理。

#include<iostream>
using namespace std;
int main()
{
	__int64 a,b;
	while(scanf("%I64X%I64X",&a,&b))
	{
			if((a+b)>=0)
			{
				printf("%I64X\n",a+b);
			}
			else
			{
				printf("-%I64X\n",-(a+b));
			}
	}
	return 0;
}
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1877

#include<iostream>
#include<vector>
using namespace std;
int lan(vector<int> &vec,int sum,int m)
{
    while(sum > 0)
    {
        vec.push_back(sum % m);
        sum /= m;
    }
    return 0;
}
int main()
{
    int m,a,b,sum;
    vector<int> vec; //定义一个容器
    while (cin>>m && m!= 0)
    {
        cin>>a>>b;
        if(a!=0 || b!=0)
        {            
            vec.clear(); //清理容器
            lan(vec,a+b,m);    
            for (int i = vec.size() - 1; i >= 0 ; i--)//将容器中的数据倒过来输出
            {
                cout<<vec[i];
            }                
        }
        else
            cout<<"0";
        cout<<endl;
    }

    return 0;
}
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2031

#include<iostream>
#include<vector>
using namespace std;
int lan(vector<int> &vec,int sum,int m)
{
    while(sum > 0)
    {
        vec.push_back(sum % m);
        sum /= m;
    }
    return 0;
}
int main()
{
    int a,b,sum;
    vector<int> vec;
    while (cin>>a>>b )
    {
        if(a<0)
        {
            cout<<"-";
        }
        a=abs(a);
        if(a!=0)
        {        
            vec.clear();  
            lan(vec,a,b);           
            for (int i = vec.size() - 1; i >= 0 ; i--)
            {
                if(vec[i]>=10)
                {
                    printf("%X",vec[i]);
                }
                 else cout<<vec[i];
            }                
        }
        else
            cout<<"0";
        cout<<endl;
    }

    return 0;
}

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2502

#include<iostream>
#include<math.h>
#include<vector>
using namespace std;
int main()
{
	int n;
	vector<int> vec;
	while(cin>>n)
	{
		int str;
		while(n--)
		{
			cin>>str;
			int k=0;
			int s1=0,s2=0;
			s1=pow(2,str)-1; //可以由 1 2 3 找到规律,从(2^n)-1 开始
			s2=pow(2,str-1);  //到2^(n-1)结束
			
			for(int i=s2;i<=s1;i++)
			{
				vec.clear(); //清除,i 每加一次,就清理一次
				int s;  
				s=i;  //  这两行一定要有
				while(s!=0)
				{
					vec.push_back(s%2);
					s/=2;
				}
				for(int j=vec.size()-1;j>=0;j--)
				{
					if(vec[j]==1)
						k++;
				}
			}
			cout<<k<<endl;
			
		}
	}
	return 0;
}
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2097

#include<iostream>
#include<vector>
using namespace std;
int main()
{
    int n,a,b,c,d,k,g;
    vector<int> vec;
    while (cin>>n && n!=0)
    {
        int s=0,u=0,m=0;
        a=n%10;
        b=n%100/10;
        c=n%1000/100;
        d=n/1000;
        s=a+b+c+d;
        k=g=n;
        while(k!=0)
        {        
            vec.clear(); 
            vec.push_back(k%16);
            k/=16;
            for (int i = vec.size() - 1; i >= 0 ; i--)
            {    
                u+=vec[i];                
            }
        }
        while(g!=0)
        {        
            vec.clear(); 
            vec.push_back(g%12);
            g/=12;
            for (int j = vec.size() - 1; j >= 0 ; j--)
            {    
                m+=vec[j];                
            }                
        }
        if(s==m&&s==u&&m==u)
            cout<<n<<" is a Sky Number."<<endl;
        else
            cout<<n<<" is not a Sky Number."<<endl;

    }
    return 0;
}








  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值