數(shù)據(jù)結構 中數(shù)制轉換(棧的應用)
創(chuàng)新互聯(lián)建站公司2013年成立,先為達川等服務建站,達川等地企業(yè),進行企業(yè)商務咨詢服務。為達川企業(yè)網站制作PC+手機+微官網三網同步一站式服務解決您的所有建站問題。
問題描述:
將一個非負的十進制整數(shù)N轉換為另一個等價的基為B的B進制數(shù)的問題。
解答:按除2取余法,得到的余數(shù)依次是1、0、1、1,則十進制數(shù)轉化為二進制數(shù)為1101。
分析:由于最先得到的余數(shù)是轉化結果的最低位,最后得到的余數(shù)是轉化結果的最高位,因此很容易用棧來解決。
代碼如下:
#include<stdio.h> #include<malloc.h> #include<stdlib.h> typedef struct Node { int data; struct Node * pNext; }NODE ,*PNODE; typedef struct Stack { PNODE pTop; PNODE pBottom; }STACK,*PSTACK; bool empty(PSTACK ps) { if(ps->pTop == ps->pBottom) return true; else return false; } void initstack(PSTACK ps) { ps->pTop=(PNODE)malloc(sizeof(NODE)); if (NULL == ps->pTop) { printf("初始化失??!\n"); exit(-1); } else { ps->pBottom=ps->pTop; ps->pTop->pNext=NULL; } return ; } void push(PSTACK ps,int val) { PNODE pNew=(PNODE)malloc(sizeof(NODE)); pNew->data=val; pNew->pNext=ps->pTop; ps->pTop=pNew; return; } void pop(PSTACK ps) { int x; if(empty(ps)) { //printf("出棧失?。?); return ; } else { PNODE p=ps->pTop; x=p->data; ps->pTop=p->pNext; free(p); p=NULL; printf("%d",x); return ; } } int main() { int i,N,B; STACK S; scanf("%d",&N); scanf("%d",&B); initstack(&S); while(N) { push(&S,N%B); N=N/B; } while(S.pBottom!=NULL) { pop(&S); } system("pause"); return 0; }
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
網站欄目:數(shù)據(jù)結構中數(shù)制轉換(棧的應用)
網頁路徑:http://aaarwkj.com/article38/jeiipp.html
成都網站建設公司_創(chuàng)新互聯(lián),為您提供微信小程序、品牌網站制作、網站排名、品牌網站設計、Google、移動網站建設
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)