蓝桥杯基础练习 十六进制转八进制 c++
题目要求:
资源限制
时间限制:1.0s 内存限制:512.0MB
问题描述
给定n个十六进制正整数,输出它们对应的八进制数。
输入格式
输入的第一行为一个正整数n (1<=n<=10)。
接下来n行,每行一个由09、大写字母AF组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。
输出格式
输出n行,每行为输入对应的八进制正整数。
【注意】
输入的十六进制数不会有前导0,比如012A。
输出的八进制数也不能有前导0。
样例输入
2
39
123ABC
样例输出
71
4435274
【提示】
先将十六进制数转换成某进制数,再由某进制数转换成八进制。
提交代码:
#include<bits/stdc++.h>
using namespace std;
int main()
{
string s1,s2;
int n;
cin>>n;
for(int i=0;i<n;i++)
{
cin>>s1;
s2="";
for(int j=0;j<s1.length();j++)
{
if(s1[j]=='0') s2+="0000";
if(s1[j]=='1') s2+="0001";
if(s1[j]=='2') s2+="0010";
if(s1[j]=='3') s2+="0011";
if(s1[j]=='4') s2+="0100";
if(s1[j]=='5') s2+="0101";
if(s1[j]=='6') s2+="0110";
if(s1[j]=='7') s2+="0111";
if(s1[j]=='8') s2+="1000";
if(s1[j]=='9') s2+="1001";
if(s1[j]=='A') s2+="1010";
if(s1[j]=='B') s2+="1011";
if(s1[j]=='C') s2+="1100";
if(s1[j]=='D') s2+="1101";
if(s1[j]=='E') s2+="1110";
if(s1[j]=='F') s2+="1111";
}
if(s2.length()%3==1) s2="00"+s2;
if(s2.length()%3==2) s2="0"+s2;
int flag=0;
for(int k=0;k<s2.length()-2;k+=3)
{
int p=4*(s2[k]-'0')+2*(s2[k+1]-'0')+s2[k+2]-'0';
if(p) flag=1;
if(flag) cout<<p;
}
cout<<endl;
}
}
注意事项
字符串s1获得所需十六进制数,并通过if语句转换为二进制的形式存入另一个字符串s2。
二进制转换为八进制是以三个二进制位为一组的,考虑到字符串的长度可能不被三整除,故使用if函数对不被三整除的两种情况进行前加0处理。
最后一个部分就是将二进制逐三个转换为八进制并逐个八进制位输出
注:考虑到可能前三位均为0,因此需要进行去0判断
参考内容
https://blog.csdn.net/aidwao/article/details/104092112