【进制转换】如何使用C++将一个十进制数转为16进制?

题目

题目描述
请从键盘读入一个非负整数n(n是一个不超过18位的正整数),将n转换为16进制!
注意:16进制即逢16进1,每一位上可以是从小到大为0、1、2、3、4、5、6、7、8、9、A、B、C、D、E、F共16个大小不同的数,即逢16进1,其中用A,B,C,D,E,F这六个字母来分别表示10,11,12,13,14,15。
如:60的十六进制为3C。(字母请用大写)

**输入**
一个不超过18位的非负整数n

输出
该数的十六进制值

样例输入
100000000000

样例输出
174876E800

程序实现

方法一

#include <iostream>
using namespace std;

long long n, x;
string s;
char c;

int main(){
	/*
		条件: 
			n是一个不超过18位的正整数。 
		注意:
			int最多表达到 2^31 - 1,10位整数。 
			long long 最多表达到 2^63 - 1,19位整数。
		
		思路:
			逆序存储到字符串时要注意:
			整数 0 ~ 9,转换为字符 '0' ~ '9',x + '0' 
			整数 10 ~ 15,转换为字符 'A' ~ 'F',x + 'A' - 10 或 x + 55 
	*/
	cin >> n;
	
	while(n != 0){
		x = n % 16;
//		cout << x << endl;
		if(x < 10){
			c = x + '0';
		}else{
			c = x + 'A' - 10;
		}
		
		s = c + s;
		
		n = n / 16;
	}
	
//	cout << s;

	if(s == ""){
		cout << 0; 
	}else{
		cout << s;
	}
}

方法二

#include <iostream>
using namespace std;

long long n, x;
string s;
string t = "0123456789ABCDEF";

int main(){
	/*
		条件: 
			n是一个不超过18位的正整数。 
		注意:
			int最多表达到 2^31 - 1,10位整数。 
			long long 最多表达到 2^63 - 1,19位整数。
		
		思路:
			逆序存储到字符串时要注意:
			整数 0 ~ 9,转换为字符 '0' ~ '9',x + '0' 
			整数 10 ~ 15,转换为字符 'A' ~ 'F',x + 'A' - 10 或 x + 55 
	*/
	cin >> n;
	
	while(n != 0){
		x = n % 16;
		// 将 n % 16 转换为字符逆序存入 s 
		s = t[x] + s;
		n = n / 16;
	}

	if(s == ""){
		cout << 0; 
	}else{
		cout << s;
	}
}
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值