东华OJ进阶题81 16进制加法

81 16进制加法

作者: xxx时间限制: 1S章节: 字符串

问题描述 :

某天、小晨在路上背着单词,突遇一外星人,外星人对小晨很感兴趣,为了考验小晨的智商,就向小晨提问简单加法,由于外星人使用16进制,所以,小晨必须用16进制回答。

输入说明 :

首先输入一个整数T,

以下T行,每行两个16进制数字

输出说明 :

T行,每行一个16进制数,为求出的两数之和。

其中的英文字母a到f为小写。

输入范例 :

2
4b0d 4887
2745 7438
输出范例 :

9394
9b7d

#include <stdio.h>
#include <math.h>
int main(){
	char number[16]={'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'};
	int T;
	while(scanf("%d",&T)!=EOF){
		while(T--){
		char a[100],b[100];
		scanf("%s%s",a,b);//以空格作为结束标志 
		char s1[100];
		int i=0;
		int j=0;
		int sum1=0;
		int sum2=0;
		int count1=0;
		int count2=0;
		while(a[i]!='\0')
		{count1++;
		i++;
			}	
		 i=0;
		while(b[i]!='\0')
			{
				count2++;
				i++;
			}
		i=0;
		while(a[i]!='\0'){
			for(j=0;j<16;j++)
			{
				if(a[i]==number[j])
					sum1+=j*pow(16,count1-1-i);
			}
			i++;
			j=0;
		}
		i=0;
		while(b[i]!='\0'){
			for(j=0;j<16;j++)
			{
				if(b[i]==number[j])
					sum2+=j*pow(16,count2-1-i);
			}
			i++;
			j=0;
		}
		int sum=sum1+sum2;
		i=0;
		while(sum){
			s1[i++]=number[sum%16];
			sum=sum/16;	
		}
		for(j=i-1;j>=0;j--)
			printf("%c",s1[j]);
			printf("\n");
		}
		
	}
	return 0;
}

原以为比较简单,中间很多细节都没有注意。值得反思。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值