首页
/
每日頭條
/
生活
/
八進制轉換二進制方法
八進制轉換二進制方法
更新时间:2026-03-24 22:05:57

題目要求:

編寫一個程序,要求從終端輸入一串0/1表示的二進制數,輸出它的八進制表示形式。

八進制轉換二進制方法(二進制八進制轉換器)1

二進制轉八進制的過程

将棧A的10轉換為2,存放到棧B中;

主要考點是練習動态申請内存空間;

#include "stdio.h" #include "math.h" #define STACK_INIT_SIZE 20 #define STACKINCREMENT 10 typedef char ElemType; typedef struct{ ElemType *base; ElemType *top; int stacksize; }sqStack; /*初始化棧*/ void initStack(sqStack *s) { /*内存中開辟一段連續空間作為棧空間,首地址賦值給s->base*/ s->base = (ElemType *)malloc(STACK_INIT_SIZE * sizeof(ElemType)); if(!s->base) exit(0); /*分配空間失敗*/ s->top = s->base; /*最開始,棧頂就是棧底*/ s->stacksize = STACK_INIT_SIZE; /*最大容量為STACK_INIT_SIZE */ } /*入棧操作,将e壓入棧中*/ void Push(sqStack *s, ElemType e){ if(s->top - s->base >= s->stacksize){ /*棧滿,追加空間*/ s->base = (ElemType *)realloc(s->base, (s->stacksize STACKINCREMENT)*sizeof(ElemType)); if(!s->base) exit(0); /*存儲分配失敗*/ s->top = s->base s->stacksize; s->stacksize = s->stacksize STACKINCREMENT; /*設置棧的最大容量*/ } *(s->top) = e; /*放入數據*/ s->top ; } /*出棧操作,用e将棧頂元素返回*/ void Pop(sqStack *s , ElemType *e){ if(s->top == s->base) return; *e = *--(s->top); } /*計算棧s的當前長度*/ int StackLen(sqStack s){ return (s.top - s.base) ; } main() { ElemType c; sqStack s1; sqStack s2; int len,i,j,sum = 0; initStack(&s1); /*創建一個棧s1,用來存放二進制字符串*/ printf("Please input a binary number and type # for end\n"); /*輸入0/1字符表示的二進制數,以#結束*/ scanf("%c",&c); while(c!='#') { if(c=='0' || c=='1') Push(&s1,c); scanf("%c",&c); } initStack(&s2); /*創建一個棧s2,用來存放八進制字符串*/ len = StackLen(s1); /*得到棧中的元素個數,即二進制數的長度*/ for(i=0;i<len;i=i 3){ for(j=0;j<3;j ){ Pop(&s1,&c); /*取出棧頂元素*/ sum = sum (c-48) * pow(2,j); /*轉換為八進制數*/ if(s1.base == s1.top) break; } Push(&s2,sum 48) ; /*将八進制數以字符形式壓入棧中*/ sum = 0; } while(s2.base != s2.top ){ /*輸出八進制棧的内容*/ Pop(&s2,&c); printf("%c",c); } getche(); }

運行結果:

八進制轉換二進制方法(二進制八進制轉換器)2

運行結果

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
番茄桂花魚湯怎麼做
番茄桂花魚湯怎麼做
番茄桂花魚湯怎麼做?主料:桂魚1條(1斤左右的最好)、蕃茄2-3個、蘑菇适量、姜片、蔥花調料:蕃茄醬、鹽、雞精、胡椒粉、生粉、料酒,今天小編就來說說關于番茄桂花魚湯怎麼做?下面更多詳細答案一起來看看吧!番茄桂花魚湯怎麼做主料:桂魚1條(1斤...
2026-03-24
孔夫子念三字經的歇後語
孔夫子念三字經的歇後語
與孔夫子有關的歇後語你知道多少1、孔夫子的門徒——閑{賢}人2、孔父子搬場——盡是輸{書)3、孔夫子的墳——久慕(墓)年夜名4、孔夫子講學——之乎者也5、孔夫子的嘴巴——七步之才孔夫子唱戲——七步之才6、孔夫子拿掃帚——斯文掃地7、孔夫子教...
2026-03-24
海參簡易家常做法
海參簡易家常做法
海參的十大家常做法春筍燒海參材料:梅頭肉,生粉,生抽,酒,姜,筍條,海參,糖,醬油,蚝油,蔥花做法:1.梅頭肉切片用生粉生抽酒腌一會.2.把油鍋燒熱後放幾片姜.3.再放肉片先炒一會加筍條.海參.4.放點糖再下醬油/水一起焖煮到筍熟透加點蚝油...
2026-03-24
11.98萬16.98萬傳祺影酷正式上市
11.98萬16.98萬傳祺影酷正式上市
傳祺影酷相信大家并不陌生,不過所了解的主要是1.5T動力以及2.0L混動車型,2.0T車型更多的行走于無聲之處。機會永遠是留給有準備的人,不對,機會永遠留給那些有機會的人,在影酷3萬公裡環行中國的收官之站,我們專挑了2.0T車型進行重點體驗...
2026-03-24
杭州一号地鐵通蕭山機場沒
杭州一号地鐵通蕭山機場沒
都市快報今天(5月24日)上午,随着杭州地鐵1号線三期工程蕭山機場站最後一塊頂闆混凝土澆築完成,1号線三期5個車站均實現主體結構完工目标,朝着年底建成的目标邁出了堅實的一步。地鐵1号線三期起于下沙江濱站,之後穿江而過,一路接入蕭山機場,共設...
2026-03-24
Copyright 2023-2026 - www.tftnews.com All Rights Reserved