蓝桥杯-----十六进制转八进制

xiaoxiao2025-07-28  23

基础练习 十六进制转八进制

问题描述

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

输入格式

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

输出格式

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

样例输入

       2   39   123ABC

样例输出

        71   4435274

解题思路

       可将16进制数先转为2进制数,再利用2进制数转为8进制

代码如下:

#include<iostream> #include<cstdio> using namespace std; char z[400000]; int main() { string a; int j,i=0,k; int n; cin>>n; while(n--) { cin>>a; i=a.length(); //cout<<i<<endl; k=0; for(j=0;j<i;j++) { switch(a[j]) { case '0':z[k]='0';z[k+1]='0';z[k+2]='0';z[k+3]='0';k+=4;break; case '1':z[k]='0';z[k+1]='0';z[k+2]='0';z[k+3]='1';k+=4;break; case '2':z[k]='0';z[k+1]='0';z[k+2]='1';z[k+3]='0';k+=4;break; case '3':z[k]='0';z[k+1]='0';z[k+2]='1';z[k+3]='1';k+=4;break; case '4':z[k]='0';z[k+1]='1';z[k+2]='0';z[k+3]='0';k+=4;break; case '5':z[k]='0';z[k+1]='1';z[k+2]='0';z[k+3]='1';k+=4;break; case '6':z[k]='0';z[k+1]='1';z[k+2]='1';z[k+3]='0';k+=4;break; case '7':z[k]='0';z[k+1]='1';z[k+2]='1';z[k+3]='1';k+=4;break; case '8':z[k]='1';z[k+1]='0';z[k+2]='0';z[k+3]='0';k+=4;break; case '9':z[k]='1';z[k+1]='0';z[k+2]='0';z[k+3]='1';k+=4;break; case 'A':z[k]='1';z[k+1]='0';z[k+2]='1';z[k+3]='0';k+=4;break; case 'B':z[k]='1';z[k+1]='0';z[k+2]='1';z[k+3]='1';k+=4;break; case 'C':z[k]='1';z[k+1]='1';z[k+2]='0';z[k+3]='0';k+=4;break; case 'D':z[k]='1';z[k+1]='1';z[k+2]='0';z[k+3]='1';k+=4;break; case 'E':z[k]='1';z[k+1]='1';z[k+2]='1';z[k+3]='0';k+=4;break; case 'F':z[k]='1';z[k+1]='1';z[k+2]='1';z[k+3]='1';k+=4;break; } } /*for(i=0;i<k;i++) cout<<z[i]; cout<<endl;*/ if(k%3==0) { for(i=0;i<k;) { if(z[i]=='0'&&z[i+1]=='0'&&z[i+2]=='0'&&i!=0) {cout<<'0';i+=3;} else if(z[i]=='0'&&z[i+1]=='0'&&z[i+2]=='0'&&i==0) {i+=3;} else if(z[i]=='0'&&z[i+1]=='0'&&z[i+2]=='1') {cout<<'1';i+=3;} else if(z[i]=='0'&&z[i+1]=='1'&&z[i+2]=='0') {cout<<'2';i+=3;} else if(z[i]=='0'&&z[i+1]=='1'&&z[i+2]=='1') {cout<<'3';i+=3;} else if(z[i]=='1'&&z[i+1]=='0'&&z[i+2]=='0') {cout<<'4';i+=3;} else if(z[i]=='1'&&z[i+1]=='0'&&z[i+2]=='1') {cout<<'5';i+=3;} else if(z[i]=='1'&&z[i+1]=='1'&&z[i+2]=='0') {cout<<'6';i+=3;} else if(z[i]=='1'&&z[i+1]=='1'&&z[i+2]=='1') {cout<<'7';i+=3;} } cout<<endl; } if(k%3==1) { if(z[0]=='1') cout<<'1'; for(i=1;i<k;) { if(z[i]=='0'&&z[i+1]=='0'&&z[i+2]=='0') {cout<<'0';i+=3;} else if(z[i]=='0'&&z[i+1]=='0'&&z[i+2]=='1') {cout<<'1';i+=3;} else if(z[i]=='0'&&z[i+1]=='1'&&z[i+2]=='0') {cout<<'2';i+=3;} else if(z[i]=='0'&&z[i+1]=='1'&&z[i+2]=='1') {cout<<'3';i+=3;} else if(z[i]=='1'&&z[i+1]=='0'&&z[i+2]=='0') {cout<<'4';i+=3;} else if(z[i]=='1'&&z[i+1]=='0'&&z[i+2]=='1') {cout<<'5';i+=3;} else if(z[i]=='1'&&z[i+1]=='1'&&z[i+2]=='0') {cout<<'6';i+=3;} else if(z[i]=='1'&&z[i+1]=='1'&&z[i+2]=='1') {cout<<'7';i+=3;} } cout<<endl; } if(k%3==2) { if(z[0]=='0'&&z[1]=='1') cout<<'1'; else if(z[0]=='1'&&z[1]=='0') cout<<'2'; else if(z[0]=='1'&&z[1]=='1') cout<<'3'; for(i=2;i<k;) { if(z[i]=='0'&&z[i+1]=='0'&&z[i+2]=='0') {cout<<'0';i+=3;} else if(z[i]=='0'&&z[i+1]=='0'&&z[i+2]=='1') {cout<<'1';i+=3;} else if(z[i]=='0'&&z[i+1]=='1'&&z[i+2]=='0') {cout<<'2';i+=3;} else if(z[i]=='0'&&z[i+1]=='1'&&z[i+2]=='1') {cout<<'3';i+=3;} else if(z[i]=='1'&&z[i+1]=='0'&&z[i+2]=='0') {cout<<'4';i+=3;} else if(z[i]=='1'&&z[i+1]=='0'&&z[i+2]=='1') {cout<<'5';i+=3;} else if(z[i]=='1'&&z[i+1]=='1'&&z[i+2]=='0') {cout<<'6';i+=3;} else if(z[i]=='1'&&z[i+1]=='1'&&z[i+2]=='1') {cout<<'7';i+=3;} } cout<<endl; } } return 0; }

 

转载请注明原文地址: https://www.6miu.com/read-5033859.html

最新回复(0)