蓝桥杯题库:十六进制转八进制

问题描述
  给定n个十六进制正整数,输出它们对应的八进制数。

输入格式
  输入的第一行为一个正整数n (1<=n<=10)。
  接下来n行,每行一个由09、大写字母AF组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。

输出格式
  输出n行,每行为输入对应的八进制正整数。

【注意】
  输入的十六进制数不会有前导0,比如012A。
  输出的八进制数也不能有前导0。

样例输入
  2
  39
  123ABC

样例输出
  71
  4435274

思路:刚开始想得是先转换成十进制,但是字符串长度太大了。所以先转化成二进制,转化成二进制之后,如果字符串长度不是3的倍数,就在前面补0,每三位二进制数化为一个八进制数即可。

AC代码:

#include<bits/stdc++.h>
using namespace std;

int n;
string res,ans;
stack<int> s,t;
string binary[]={"0000","0001","0010","0011","0100","0101","0110","0111","1000","1001","1010",
"1011","1100","1101","1110","1111"};  //先定义好0-16的二进制数 
map<string,string> a;

void init() {
	a["000"]="0";    //二八转换 
	a["001"]="1";
	a["010"]="2";
	a["011"]="3";
	a["100"]="4";
	a["101"]="5";
	a["110"]="6";
	a["111"]="7";
}
void converse(string str) {
	res="";
	ans="";
	int cur;
	for(int i=0;i<str.length();i++) {
		if(str[i]>='0'&&str[i]<='9') {
			cur=(int)(str[i]-48);
		}else {
			cur=(int)(str[i]-55);
		}
		res+=binary[cur];   //转成二进制 
	}
	int n=res.length();
	int x=n%3;
	if(x==1) {
		res="00"+res;   //补0
	}else if(x==2) {
		res="0"+res;
	}
	for(int i=0;i<res.length();i+=3) {
		ans+=a[res.substr(i,3)];   //每三位转成一位八进制数 
	}
	int i=0;
	for(i=0;i<ans.length();i++) {
		if(ans[i]!='0') {   //注意不能输出前导0 
			break;
		}
	}
	ans.erase(0,i);
	cout<<ans<<endl;
}

int main() {
	init();
	int n;
	cin>>n;
	string str;
	for(int i=1;i<=n;i++) {
		cin>>str;
		converse(str);
	}
	return 0;
}

  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Cyril_KI

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值