首页
/
每日頭條
/
生活
/
八進制轉換二進制方法
八進制轉換二進制方法
更新时间:2025-12-27 03:01:31

題目要求:

編寫一個程序,要求從終端輸入一串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
推荐阅读
監理項目個人承包有哪些費用
監理項目個人承包有哪些費用
監理項目個人承包有哪些費用?加盟工程監理分公司,從總公司過賬請款流程有哪些?關鍵在于必須填好請款單,然後就是遞交請款的資料請款資料分成提前準備階段資料、工程施工階段資料、工程驗收階段資料加盟代理監理子公司以後,從總公司過賬請款需提供請款應提...
2025-12-27
屁多肚子反複脹氣是什麼原因
屁多肚子反複脹氣是什麼原因
脹氣有時是令人尴尬且不适的,學會這幾招,避免脹氣帶來的尴尬問題。“問上醫”用美國家庭醫生智庫為您介紹。吃飯以及消化食物的過程中,我們的體内常會滞留一些氣體。之後,它們會通過多種方式被排出體外。根據氣體排出的方式及存在的位置,可将脹氣分為打嗝...
2025-12-27
彌勒溫泉含什麼
彌勒溫泉含什麼
沒有溫泉的冬天一定是不完整的彌勒這些景色獨特、優質舒适的溫泉今冬必須打卡湖泉半山溫泉近日榮獲雲南“十佳溫泉”的湖泉半山溫泉,擁有豐富的地熱資源,水溫常年50℃左右,溫暖舒适。該溫泉含有多種對人體有益的礦物質微量元素,具有較強的潤膚保健功效。...
2025-12-27
可樂雞翅根需要做多長時間能熟
可樂雞翅根需要做多長時間能熟
ByJ513Q用料雞翅根10個料酒兩勺姜三片蔥花一小把可樂200毫升生抽5勺油兩勺做法步驟1、蔥姜切絲備用(再切兩片姜和兩塊蔥留出煮蔥姜水)2、一天的蔥姜水放入兩勺料酒再把翅根放進去(翅根可以先用蔥姜料酒醬油腌一會兒)3、腌一會兒會更入味4...
2025-12-27
高通何時超越蘋果
高通何時超越蘋果
據國外媒體報道,在iPhoneX上市和2017财年第四季度财報的刺激下,蘋果股價上周四至今一直在上漲,目前股價達到了176.24美元,市值已超過9100億美元,距離1萬億美元已越來越近。蘋果股價蘋果市值已超9100億美元周三美國股市收盤時,...
2025-12-27
Copyright 2023-2025 - www.tftnews.com All Rights Reserved