<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
利用棧的資料結構實現將十進位制數轉換成二進位制數
順序表的儲存結構實現棧
程式碼:
#include <stdlib.h> #include <stdio.h> #define STACK_INIT_SIZE 100 //棧初始開闢空間大小 #define STACK_INCREMENT 10 //棧追加空間大小 //棧的結構體 typedef struct stack{ int *base; int *top; int size; }binStack; //棧初始化 binStack stack_init() { binStack bs; bs.base = (int *)malloc(sizeof(int)*STACK_INIT_SIZE); bs.top = bs.base; bs.size = STACK_INIT_SIZE; return bs; } //入棧 void push(binStack *bs, int e) { if(bs->top - bs->base >= bs->size) { bs->size += STACK_INCREMENT; bs->base = realloc(bs->base, bs->size); } *(bs->top++) = e; } //出棧 int pop(binStack *bs) { if(bs->top != bs->base) { bs->top--; return *bs->top; } return -1; } //主函數 void main() { int dec; binStack bs = stack_init(); printf("請輸入十進位制整數:n"); scanf("%d", &dec); while(dec) { push(&bs, dec%2); dec /= 2; } printf("轉換後的二進位制數是:n"); while(bs.top != bs.base) { printf("%d", pop(&bs)); } printf("nn"); system("date /T"); system("TIME /T"); system("pause"); exit(0); }
執行結果:
對於stack我們可以使用python內建的list實現(也可以用連結串列實現),因為list是屬於線性陣列,在末尾插入和刪除一個元素所使用的時間都是O(1),這非常符合stack的要求。
程式碼:
import datetime //顯示時間引入的庫 import time // from pip._vendor.distlib.compat import raw_input //使命令視窗不立即關閉引入的庫 //棧類 class BinStack: def __init__(self): self.bs = [] //入棧 def push(self, e): self.bs.append(e) //出棧 def pop(self): if self.bs: return self.bs.pop() else: raise LookupError("stack is empty!") //檢查棧是否為空,是返回False,不是返回True def isEmpty(self): return bool(self.bs) if __name__ == '__main__': binStack = BinStack() dec = int(input("請輸入十進位制整數:n")) print("轉換後的二進位制數是:") while dec != 0: binStack.push(dec%2) dec //= 2 while binStack.isEmpty() == True: print("{}".format(binStack.pop()), end="") else: print("n") //列印時間 datetime = datetime.datetime.now() print(datetime.strftime("%Y-%m-%dn%H:%M:%S")) //使命令視窗不立即關閉 input("Press Enter to exit…")
執行結果:
以上就是Python和C語言利用棧分別實現進位制轉換的詳細內容,更多關於Python進位制轉換的資料請關注it145.com其它相關文章!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45