



全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
基础练习 十六进制转八进制 时间限制:1.0s 内存限制:512.0MB 问题描述给定n个十六进制正整数,输出它们对应的八进制数。输入格式输入的第一行为一个正整数n (1=n=10)。接下来n行,每行一个由09、大写字母AF组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。输出格式输出n行,每行为输入对应的八进制正整数。注意输入的十六进制数不会有前导0,比如012A。输出的八进制数也不能有前导0。样例输入239123ABC样例输出714435274提示先将十六进制数转换成二进制数,再由二进制数转换成八进制。程序:#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,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: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,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;/说明还有三位二进制数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;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;List 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.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
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024~2025学年上海八年级数册末试题
- 合同管理流程再造考核试卷
- 糖业绿色生产技术发展考核试卷
- 绩效管理中的绩效改进计划实施效果评估考核试卷
- 组织变革与员工敬业度考核试卷
- 城市公共设施可持续发展评价体系构建考核试卷
- 模具设计中的模具设计成本控制策略考核试卷
- 光学校准器校准系统标准化流程建立考核试卷
- 2025年中国PP线绕滤芯数据监测研究报告
- 2025年中国OPP水性覆膜机数据监测报告
- NB/T 11127-2023在用钢丝绳芯输送带报废检测技术规范
- 电商平台法人免责协议书
- 柴油供应垫资合同范本
- 居间权益保障协议
- 成品金属格栅施工方案
- DBJ04-T 432-2022 建设工程全过程造价咨询标准
- 山东省济南市(2024年-2025年小学四年级语文)人教版期末考试((上下)学期)试卷及答案
- 人美 版三年级美术下册(北京)《18.设计紧急避难路线图》教学设计
- SLT 478-2021 水利数据库表结构及标识符编制总则
- 《霍山石斛》课件
- 浙江省杭州市西湖区2025届数学七年级第一学期期末考试试题含解析
评论
0/150
提交评论