您好,登錄后才能下訂單哦!
問(wèn)題描述
給定n個(gè)十六進(jìn)制正整數(shù),輸出它們對(duì)應(yīng)的八進(jìn)制數(shù)。
輸入格式
輸入的第一行為一個(gè)正整數(shù)n (1<=n<=10)。
接下來(lái)n行,每行一個(gè)由0~9、大寫(xiě)字母A~F組成的字符串,表示要轉(zhuǎn)換的十六進(jìn)制正整數(shù),每個(gè)十六進(jìn)制數(shù)長(zhǎng)度不超過(guò)100000。
輸出格式
輸出n行,每行為輸入對(duì)應(yīng)的八進(jìn)制正整數(shù)。
【注意】
輸入的十六進(jìn)制數(shù)不會(huì)有前導(dǎo)0,比如012A。
輸出的八進(jìn)制數(shù)也不能有前導(dǎo)0。
樣例輸入
2
39
123ABC
樣例輸出
71
4435274
【提示】
先將十六進(jìn)制數(shù)轉(zhuǎn)換成某進(jìn)制數(shù),再由某進(jìn)制數(shù)轉(zhuǎn)換成八進(jìn)制。
#include <iostream>
using namespace std;
int main()
{
int n=0; //記錄輸入數(shù)據(jù)的個(gè)數(shù)
cin>>n;
string sixTeen[10]; //用來(lái)記錄輸入的數(shù)據(jù)
for(int i=0;i<n;i++)
{
cin>>sixTeen[i];
}
for(int i=0;i<n;i++)
{
string eight;//記錄八進(jìn)制數(shù)據(jù)
string tow; //記錄二進(jìn)制數(shù)據(jù)
char eig;
//轉(zhuǎn)換為二進(jìn)制
for(int j=0;j<sixTeen[i].length();j++)
{
switch(sixTeen[i][j])
{
case '0':tow+="0000";break;
case '1':tow+="0001";break;
case '2':tow+="0010";break;
case '3':tow+="0011";break;
case '4':tow+="0100";break;
case '5':tow+="0101";break;
case '6':tow+="0110";break;
case '7':tow+="0111";break;
case '8':tow+="1000";break;
case '9':tow+="1001";break;
case 'A':tow+="1010";break;
case 'B':tow+="1011";break;
case 'C':tow+="1100";break;
case 'D':tow+="1101";break;
case 'E':tow+="1110";break;
case 'F':tow+="1111";break;
default:break;
}
}
//轉(zhuǎn)換為八進(jìn)制
//首先補(bǔ)齊“0”
int m=tow.length()%3;
if(m==1)
tow.insert(0,"00");
else if(m==2)
tow.insert(0,"0");
//進(jìn)行轉(zhuǎn)換
if(!(tow[0]=='0'&&tow[1]=='0'&&tow[2]=='0'))
{
eig=(tow[0]-'0')4+(tow[1]-'0')2+(tow[2]);
eight=eight+eig;
}
for(int k=3;k<tow.length();k=k+3)
{
//eig=(tow[k3]-'0')4+(tow[k3+1]-'0')2+(tow[k*3+2]);
//eight=eight+eig;
if(tow.substr(k,3)=="000")
eight+="0";
else if(tow.substr(k,3)=="001")
eight+="1";
else if(tow.substr(k,3)=="010")
eight+="2";
else if(tow.substr(k,3)=="011")
eight+="3";
else if(tow.substr(k,3)=="100")
eight+="4";
else if(tow.substr(k,3)=="101")
eight+="5";
else if(tow.substr(k,3)=="110")
eight+="6";
else if(tow.substr(k,3)=="111")
eight+="7";
}
//輸出最終的八進(jìn)制數(shù)
cout<<eight<<endl;
}
return 0;
}
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。