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

上传人:pu****.1 文档编号:567592229 上传时间:2024-07-21 格式:PDF 页数:4 大小:73.78KB
返回 下载 相关 举报
基础练习 十六进制转八进制_第1页
第1页 / 共4页
基础练习 十六进制转八进制_第2页
第2页 / 共4页
基础练习 十六进制转八进制_第3页
第3页 / 共4页
基础练习 十六进制转八进制_第4页
第4页 / 共4页
亲,该文档总共4页,全部预览完了,如果喜欢就下载吧!
资源描述

《基础练习 十六进制转八进制》由会员分享,可在线阅读,更多相关《基础练习 十六进制转八进制(4页珍藏版)》请在金锄头文库上搜索。

1、基础练习基础练习 十六进制转八进制十六进制转八进制时间限制:时间限制:1.0s1.0s内存限制:内存限制:512.0MB512.0MB问题描述问题描述给定 n 个十六进制正整数,输出它们对应的八进制数。输入格式输入格式输入的第一行为一个正整数n 1=n=10 。接下来 n 行,每行一个由 09、大写字母 AF 组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。输出格式输出格式输出 n 行,每行为输入对应的八进制正整数。注意注意输入的十六进制数不会有前导0,比方 012A。输出的八进制数也不能有前导0。样例输入样例输入239123ABC样例输出样例输出7144352

2、74提示提示先将十六进制数转换成二进制数,再由二进制数转换成八进制。程序:#include#include#include#define MAXsize 100000void savebin(char *b,char *ch,int index)/保存二进制 01 字串bindex=ch0;b+index=ch1;b+index=ch2;b+index=ch3;void hextobin(char *h,char *b)/十六进制转二进制char t165=0000,0001,0010,0011,0100,0101,0110,0111,1000,1001,1010,1011,1100,1101

3、,1110,1111;int i = 0;for(;hi!=0;i+)switch(hi)case 0:savebin(b,t0,i*4);break;case 1:savebin(b,t1,i*4);break;case 2:savebin(b,t2,i*4);break;case 3:savebin(b,t3,i*4);break;case 4:savebin(b,t4,i*4);break;case 5:savebin(b,t5,i*4);break;case 6:savebin(b,t6,i*4);break;case 7:savebin(b,t7,i*4);break;case 8:

4、savebin(b,t8,i*4);break;case 9:savebin(b,t9,i*4);break;case A:savebin(b,t10,i*4);break;case B:savebin(b,t11,i*4);break;case C:savebin(b,t12,i*4);break;case D:savebin(b,t13,i*4);break;case E:savebin(b,t14,i*4);break;case F:savebin(b,t15,i*4);break;b4*i = 0;void bintooct(char *b,char *o)int i,j;int bl

5、,ol;/确定八进制数的长度bl = strlen(b);ol = ceil(bl / 3.0);/将二进制从高位向低位转换,逆序保存j = bl - 1;i = ol - 1;for(; i = 0; -i, j -= 3)if(i 0)oi=bj+(bj-1-48)*2+(bj-2-48)*4;/权位值从低到高为:1 2 4elseswitch(j)case 0:oi=bj;break;/说明只有一位二进制数case 1:oi=bj+(bj-1-48)*2;break;/说明还有两位二进制数case 2:oi=bj+(bj-1-48)*2+(bj-2-48)*4;break;/说明还有三位

6、二进制数ool = 0;void print(char *o)/打印八进制int i = 0;while(oi=0)/排除首位为0的情况+i;printf(%sn,&oi);int main()char hMAXsize;/建立十六进制数组,长度为10 万char bMAXsize*4+1;/建立二进制数组,长度为4 倍十六进制长度char oMAXsize*4/3+1;/建立八进制数组int i,n;scanf(%d,&n);getchar();for(i=0;in;i+)gets(h);hextobin(h,b);bintooct(b,o);print(o);return 0;学习文档 仅

7、供参考JAVA 程序:import java.util.ArrayList;import java.util.List;import java.util.Scanner;public class B5 public static void main(String args) int n,m;char x;Strings=0000,0001,0010,0011,0100,0101,0110,0111,1000,1001,1010,1011,1100,1101,1110,1111;StringBuffer sb;String ss,zero=0000;char a=new char400002;L

8、ist num;Scanner sc=new Scanner(System.in);n=sc.nextInt();for(int i=0;in;i+)ss=sc.next();long time1 = System.currentTimeMillis();sb=new StringBuffer();num=new ArrayList();for(int j=0;jss.length();j+)x=ss.charAt(j);m=Integer.parseInt(String.valueOf(x),16);sb.append(sm);m=sb.length()%3;sb.insert(0,zero

9、.subSequence(0, 3-m);a=sb.toString().toCharArray();for(int j=0,k=0;jsb.length();j+=3,k+)num.add(Character.digit(aj,2)*4+Character.digit(aj+1,2)*2+Character.digit(aj+2,2);m=0;for(int j=0;jnum.size();j+)if(num.get(m)=0)m+;elseSystem.out.print(num.get(j);System.out.println();long time2 = System.currentTimeMillis();System.out.println(time2-time1);

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号