首页
/
每日頭條
/
生活
/
八進制轉換二進制方法
八進制轉換二進制方法
更新时间:2026-04-23 05:51:44

題目要求:

編寫一個程序,要求從終端輸入一串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
推荐阅读
衛生潔具選購與保養常識
衛生潔具選購與保養常識
衛生潔具是現代建築中室内配套不可缺少的組成部分。既要滿足功能要求,又要考慮節能、節水的新階段。衛生器具的材質,使用最多的是陶瓷、搪瓷生鐵、搪瓷鋼闆,還有水磨石等。随着建材技術的發展,國内外已相繼推出玻璃鋼、人造大理石、人造瑪瑙、不鏽鋼等新材料。衛生潔具五金配件的加工技術,也由一般的鍍鉻處理,發展到用...
2026-04-23
布藝沙發清洗方法詳解
布藝沙發清洗方法詳解
布藝沙發清洗方法詳解布藝沙發清洗方法詳解1、一般清洗流程:可以選用專用的布藝清潔劑。首先用幹淨的白布蘸上少量清潔劑,在弄髒了的地方反複擦拭,直到污漬去掉。為免留下印迹,最好是從污漬的外圍抹起。切忌大量用水擦洗,以免水滲入沙發的内層,造成沙發裡邊框受潮、變形、沙發布縮水,影響沙發的整體外觀造型。2、有...
2026-04-23
内褲正面曬還是反面曬好
内褲正面曬還是反面曬好
内褲者,又稱底褲,遮羞護私之衣片。無論三角、四角、镂空、線式……不過為輕薄一布也。然,這小小“布片”衛生與否卻與健康有大關系!據統計,六成以上的婦科炎症就是這内褲“惹”來的!那麼,健康用内褲有什麼講究呢?本期寡人就以“如何曬内褲更健康”來糾結一哈子……曬内褲最好是做“日光浴”所謂“曬内褲”,就是要讓...
2026-04-23
貼金家具保養
貼金家具保養
對于金箔,隻能談及護理,它不像地闆、瓷磚或其它的給予打蠟進行保養工作,所以隻能在日常生活中盡量減少磕碰或間接的人為破壞。貼金部分是由厚度為0.1微米左右的24K金和一種特殊的5種成份合成的溶液,經人工塗描于實木雕刻而成的飾花上,整個過程需6小時,貼好金箔48小時後方可達到滿意的硬度,其貼金表層平整光...
2026-04-23
國考一般多少進面試?
國考一般多少進面試?
國考每一年的考試情況不同,分數線也不同。近幾年一般115分以上可以進入面試,但一些競争較為激烈的部門需要150分以上才能進面試。國考全稱國家公務員考試,指中央、國家機關公務員考試,是國家部、委、署、總局招考在中央國家機關的工作人員的一種方式。國家公務員考試招考條件相對比較苛刻、嚴格,一般均要求全日制...
2026-04-23
Copyright 2023-2026 - www.tftnews.com All Rights Reserved