




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、任意進(jìn)制轉(zhuǎn)換二、需求分析進(jìn)制轉(zhuǎn)換是人們利用符號(hào)來(lái)計(jì)數(shù)的方法,包含很多種數(shù)字轉(zhuǎn)換。進(jìn)制轉(zhuǎn)換由一組數(shù)碼符號(hào)和兩個(gè)基本因素(“基”與“權(quán)”)構(gòu)成。比如二進(jìn)制下,基數(shù)是2,數(shù)碼是0和1,各數(shù)位的位權(quán)是以2為底的冪次方,進(jìn)位方法是逢二進(jìn)一,借一當(dāng)二,例如:當(dāng)今高速發(fā)展的計(jì)算機(jī)和互聯(lián)網(wǎng)產(chǎn)業(yè),正改變?nèi)藗兊纳睿偈怪祟愖呦蛄说谌喂I(yè)革命。日常生活和計(jì)算機(jī)常用的進(jìn)制包括:二進(jìn)制、六進(jìn)制、八進(jìn)制、十進(jìn)制、十六進(jìn)制、三十二進(jìn)制和六十四進(jìn)制等。但是實(shí)際生活和計(jì)算機(jī)運(yùn)算中常用的幾種進(jìn)制之間的轉(zhuǎn)換如下。需求分析之后,得到本實(shí)驗(yàn)的目的,編程實(shí)現(xiàn)常用的進(jìn)制之間的任意轉(zhuǎn)換,為了滿足計(jì)算機(jī)科學(xué)計(jì)算的要求,并考慮到負(fù)數(shù)和小數(shù)
2、的進(jìn)制轉(zhuǎn)換。三、算法設(shè)計(jì)首先理清一下常用四種進(jìn)制數(shù)下的對(duì)應(yīng)光系如下。然后整理一下各進(jìn)制。我們最常用的是十進(jìn)制,十進(jìn)制下按權(quán)展開(kāi)的多項(xiàng)式為:1. 其他進(jìn)制轉(zhuǎn)換為十進(jìn)制算法設(shè)計(jì):按權(quán)展開(kāi)用多項(xiàng)式表示再求和。(1) 二進(jìn)制(2) 八進(jìn)制(3) 十六進(jìn)制2. 十進(jìn)制轉(zhuǎn)換為其他進(jìn)制(負(fù)數(shù)、小數(shù))算法設(shè)計(jì):整數(shù)部分,除基數(shù)取余,倒序排列;小數(shù)部分,乘基數(shù)取整,順序排列;負(fù)數(shù),補(bǔ)碼,看作正數(shù),先將整數(shù)部分轉(zhuǎn)換成二進(jìn)制,取反加一。(1) 二進(jìn)制注意負(fù)數(shù)部分,將-25變成二進(jìn)制。 首先假定二進(jìn)制的位數(shù)為16位,可表示-32768到32767的所有十進(jìn)制整數(shù)。 將25表示為二進(jìn)制0000 0000 0001 10
3、01(十六進(jìn)制表示為0x0018,由于四位二進(jìn)制可以表示為一位十六進(jìn)制,故一般將二進(jìn)制按四位進(jìn)行分段表示) 將這個(gè)二進(jìn)制取反,可以得到1111 1111 11100110(十六進(jìn)制表示為0xFFE6) 將取反后的數(shù)值加上1,得到-25的二進(jìn)制表示1111 1111 11100111(十六進(jìn)制表示0xFFE7)(2) 八進(jìn)制(3) 十六進(jìn)制3. 二進(jìn)制和八、十六進(jìn)制的相互轉(zhuǎn)換算法設(shè)計(jì):二進(jìn)制轉(zhuǎn)換成八進(jìn)制,“三位一組”。以小數(shù)點(diǎn)為基點(diǎn),整數(shù)小數(shù)兩邊,每三位一組,最高處不足三位時(shí),加0補(bǔ)足,然后各組三位二進(jìn)制轉(zhuǎn)換成一個(gè)八進(jìn)制。而八進(jìn)制轉(zhuǎn)換成二進(jìn)制,正好是一個(gè)逆的過(guò)程。二進(jìn)制和十六進(jìn)制的互轉(zhuǎn),算法和八
4、進(jìn)制的一些,只是“四位一組”。例如和4. 八進(jìn)制和十六進(jìn)制的相互轉(zhuǎn)換算法設(shè)計(jì):二進(jìn)制做橋梁例如:四、編程實(shí)現(xiàn)平臺(tái):win7 64位運(yùn)行軟件: VC+6.0#include<stdio.h>#include<math.h>#include<string.h>#define P printf#define S scanf#define PF printf("n")void transform(double num,intjz)charxnum100;intdnum=(int) num;inti=0,j=0,e=0;while(dnum>
5、=jz)if(dnum%jz<10) xnumj+=dnum%jz+48;if(dnum%jz>=10) xnumj+=dnum%jz-10+'A'dnum=dnum/jz; if(dnum%jz<10) xnumj=dnum%jz+48;if(dnum%jz>=10) xnumj = dnum%jz-10+'A'for(i = j;i>=0;i-)printf("%c",xnumi); if(dnum - num != 0)printf(".");num = num - (int)num;d
6、oe+;if(int)(num*jz)<10) printf("%c",(int)(num*jz)+48);if(int)(num*jz)>=10) printf("%c",'A'+(int)(num*jz)-10);num = num*jz-(int)(num*jz);if(num = 0)break; while(e<20); double x2d(intjz,charnum)doublednum = 0;inti=0,j = 0,k=0,n=0,b;for(i;i+)if(numi='0') bre
7、ak;else n+;if(numi='.')j=i;k=1;if(k=0) / 沒(méi)有小數(shù)for(i=0;i<=n-1;i+)if(numi='A') b=10;else if(numi='B') b=11;else if(numi='C') b=12;else if(numi='D') b=13;else if(numi='E') b=14;else if(numi='F') b=15;else b=numi-'0'dnum =dnum + (double)b
8、*pow(jz,n-1-i);if(k=1) / 有小數(shù) for(i=0;i<=j-1;i+)if(numi='A') b=10;else if(numi='B') b=11;else if(numi='C') b=12;else if(numi='D') b=13;else if(numi='E') b=14;else if(numi='F') b=15;else b=numi-'0'dnum =dnum + (double)(b)*pow(jz,j-1-i); for(i=
9、j+1;i<n;i+)if(numi='A') b=10;else if(numi='B') b=11;else if(numi='C') b=12;else if(numi='D') b=13;else if(numi='E') b=14;else if(numi='F') b=15;else b=numi-'0'dnum=dnum+b*pow(jz,-(i-j);returndnum; int run(intjz, char num)switch(jz)case 2:pri
10、ntf("n8進(jìn)制: "); transform(x2d(jz, num), 8); printf("n10進(jìn)制:"); transform(x2d(jz, num), 10); printf("n16進(jìn)制:"); transform(x2d(jz, num), 16);break;case 8:printf("n2進(jìn)制: "); transform(x2d(jz, num), 2);printf("n10進(jìn)制:"); transform(x2d(jz, num), 10);printf(&qu
11、ot;n16進(jìn)制:"); transform(x2d(jz, num), 16);break;case 10:printf("n2進(jìn)制: "); transform(x2d(jz, num), 2);printf("n8進(jìn)制: "); transform(x2d(jz, num), 8);printf("n16進(jìn)制:"); transform(x2d(jz, num), 16);break;default:printf("n2進(jìn)制: "); transform(x2d(jz, num), 2);print
12、f("n8進(jìn)制: "); transform(x2d(jz, num), 8);printf("n10進(jìn)制:"); transform(x2d(jz, num), 10);break;return 0;int control(int leap) / 控制函數(shù)int p=1; char k;PF; printf("n*n");PF; PF; printf("是否繼續(xù),Y/N?n");while(p)scanf("%c",&k);if(k='Y'|k='y')
13、leap=1; PF; break;if(k='N'|k='n')leap=0; break;return(leap);int main()char num100; / 輸入的數(shù)intjz,leap=1;while(leap)printf("*n");printf("輸入的(2、8、10或16)進(jìn)制為: ");scanf("%d",&jz); / 輸入的進(jìn)制printf("請(qǐng)輸入一個(gè)該進(jìn)制的數(shù): ");scanf("%s",&num); PF;if(jz=2 | jz=8 | jz=10 | jz=16)printf("轉(zhuǎn)換結(jié)果如下:n");run(jz, num); leap=control(leap); / 控制函數(shù)elseprintf(
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年海洋服務(wù)合作協(xié)議書(shū)
- 新型保安服務(wù)模式的探索與創(chuàng)新計(jì)劃
- 班級(jí)經(jīng)驗(yàn)分享會(huì)的開(kāi)展計(jì)劃
- 培養(yǎng)學(xué)生判斷力與批判性思維計(jì)劃
- 增強(qiáng)圖書(shū)館開(kāi)放日活動(dòng)效果計(jì)劃
- 如何應(yīng)對(duì)財(cái)務(wù)恐懼癥計(jì)劃
- 經(jīng)理績(jī)效目標(biāo)規(guī)劃計(jì)劃
- 美術(shù)欣賞與文化傳播課程大綱計(jì)劃
- 幼兒心理健康關(guān)懷計(jì)劃
- 2025年藝術(shù)表演場(chǎng)館服務(wù)項(xiàng)目建議書(shū)
- 大學(xué)有機(jī)化學(xué)(王小蘭) 緒論
- 象數(shù)療法好療效
- A320系列飛行訓(xùn)練課程:電子飛行儀表系統(tǒng)概況
- 黃土地質(zhì)災(zāi)害類型及其危害性評(píng)估
- 交際德語(yǔ)教程第二版A1Studio[21] 課后習(xí)題參考答案
- 氣割、電氣焊作業(yè)的應(yīng)急救援預(yù)案
- 超級(jí)精美PPT模版美國(guó)經(jīng)典ppt模板(通用珍藏版2)
- 施工現(xiàn)場(chǎng)應(yīng)急處置方案
- 陰符咒術(shù)(基本知識(shí)--畫(huà)符)
- 氣動(dòng)控制閥的定義分類及工作原理詳解
- DZW中文說(shuō)明書(shū)
評(píng)論
0/150
提交評(píng)論