- 1、本文档共15页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
长整数的进制转换
*****大学
信息与计算科学课程设计
题 目: 长整数的进制转换
成员: 。。
。。
。。
小组成员分工: (编程、调试程序)
(编程、撰写报告)
(编程、后期整理)
一、实验目的
1、熟练掌握C语言课程中所学的基本理论和基本方法;
2、加强分析和解决问题的能力;
3、加强同学们之间的团队合作经验;
4、通过综合C语言的基本知识来解决实际问题。
二、题目要求
题目:
用一个整型数组表示一个长整数,数组的每个元素存储长整数的一位数字,则实 际的长整数m表示为:
m=a[k]×10k-1+a[k-1]×10k-2+….+a[2]×10+a[1]
其中a[0]保存该长整数的位数。
要求:
(1) 转换为16进制数输出;
(2) 转换成8进制数输出。
三、算法设计
1、长整数
(1)由题目可知,用一个整型数组表示一个长整数,数组的每个元素存储长整数的一位数字,则实际的长整数m表示为:
m=a[k]×10k-1+a[k-1]×10k-2+….+a[2]×10+a[1]
(2)长整数主程序:
_int64 Num=0;
for(i=1;i=n;i++)
{
Num+=a[n-i+1]* pow(10,i-1);
}
cout输入的长整数为:;
printf(%I64d,Num);
coutendl;
2、十进制转十六进制
英文名称Hex number system,是计算机中数据的一种表示方法。它由0-9,A-F组成,字母不区分大小写。与10进制的对应关系是:0-9对应0-9;A-F对应10-15;N进制的数可以用0---(N-1)的数表示超过9的用字母A-F。 采余数定理分解
例将487710 转成十六进制
487710÷16=30481....14(E)
30481÷16=1905....1
1905÷16=119....1
119÷16=7....7
7÷16=0....7
结果:487710(10)=7711E(16)
开始
string aa[100];int y=0;
num1!=0
int k=num1%16; num1/=16;
K是否大于10
aa[y]=k+48 switch(k)
case 10: case11: case 12: case 13: case 14: case 15:
aa[y]=Aaa[y]=B’aa[y]=Caa[y]=Daa[y]=Eaa[y]=F
break
y++
int z=y
z-- z=0 z
输出结果aa[z]
结束
3、十进制化八进制
(1)八进制:英文名称Octal,缩写OCT或O, 是计算机中数据的一种表示方法。采用0, 1,2,3,4,5,6,7八个数字,逢八进位
采余数定理分解
例:将十进制数115 转化为八进制数
115÷… 3
14÷8=1 … 6
1÷ 8=0… 1
结果115(10)=163(8)
十进制转换为八进制主程序:
void EightChange(_int64 num1)
{
string aaa[100];
文档评论(0)