c語言經典堆棧問題,C語言堆和棧

本文目錄一覽:

關於C語言堆棧的問題!

C語言中堆棧說的是數據結構,和系統中的堆棧中是不一樣的,/*

**用一個靜態數組實現的堆棧。數組的長度只能通過修改#define的定義

**並對模塊重新進行編譯

*/#include”stack.h”

#includeassert.h#define STACK_SIZE 100 /*堆棧中值數量的最大限制*//*

**存儲堆棧中值的數組和一個指向堆棧頂部元素的指針

*/

static STACK_TYPE stack[STACK_SIZE];

static int top_element =-1;/*push*/

void push(STACK_TYPE value)

{

assert(!is_full());

top_element +=1;

stack[top_element]=value;

}/*pop*/

STACK_TYPE pop(void)

{

STACK_TYPE temp;

assert(!is_empty());

temp=stack[top_element];

top_element -= 1;

return temp;

}/*top*/

STACK_TYPE top (void)

{

assert(!is_empty());

return stack[top_element];

}/*

** is _empty

*/

int is_empty(void)

{

return top_element == -1;

}/*

**is_full

*/

int is_full(void)

{

return top_element ==STACK_SIZE -1;

}這是個靜態堆棧,你可以動態的申請內存來編寫動態堆棧

C語言程序棧堆的問題

你在棧中使用了過多空間(例如開闢了超大數組)。將佔用過多空間的變量移到全局區或者使用malloc為其在堆中分配內存。

C語言中堆棧問題

我幫你寫了InitStack和StackEmpty函數,程序最終結果如下:

#define maxnum 20

#includestdio.h

#includestdlib.h

struct stacktype

{

int stack[maxnum];

int top;

};

struct stacktype *S;//頂一個堆棧

int push(struct stacktype *s,int x)

{

if(s-top=maxnum-1)

return false;

else

s-top++;

s-stack[s-top]=x;

return true;

}

int pop(struct stacktype *s)

{

if(s-top 0)

return NULL;

else

s-top–;

return(s-stack[s-top+1]);

}

//初始化堆棧

void InitStack(struct stacktype* S)

{

S = (struct stacktype *)malloc(sizeof(struct stacktype));

S-top = -1;

}

//判斷堆棧是否為空

bool StackEmpty(struct stacktype *S)

{

if (S-top 0)

{

return true;

}

return false;

}

void dec_to_bin(int n,int b)

{

int e;

InitStack(S);//請問初始化堆棧函數怎麼寫?

if (S ==NULL)

{

printf(“error \n”);

return;

}

while(n)

{

push(S,n%b);

n=n/b;

}

while(!StackEmpty(S))//判斷棧為空的函數怎麼寫?

{

e=pop(S);

printf(“%d”,e);

}

}

void main()

{

dec_to_bin(13,2);

printf(“\n”);

}

程序運行結果為:

1101

原創文章,作者:FIAC,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/137188.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
FIAC的頭像FIAC
上一篇 2024-10-04 00:17
下一篇 2024-10-04 00:17

相關推薦

  • Python官網中文版:解決你的編程問題

    Python是一種高級編程語言,它可以用於Web開發、科學計算、人工智能等領域。Python官網中文版提供了全面的資源和教程,可以幫助你入門學習和進一步提高編程技能。 一、Pyth…

    編程 2025-04-29
  • 如何解決WPS保存提示會導致宏不可用的問題

    如果您使用過WPS,可能會碰到在保存的時候提示“文件中含有宏,保存將導致宏不可用”的問題。這個問題是因為WPS在默認情況下不允許保存帶有宏的文件,為了解決這個問題,本篇文章將從多個…

    編程 2025-04-29
  • AES加密解密算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES算法,並對實現過程進…

    編程 2025-04-29
  • 學習Python對學習C語言有幫助嗎?

    Python和C語言是兩種非常受歡迎的編程語言,在程序開發中都扮演着非常重要的角色。那麼,學習Python對學習C語言有幫助嗎?答案是肯定的。在本文中,我們將從多個角度探討Pyth…

    編程 2025-04-29
  • Python被稱為膠水語言

    Python作為一種跨平台的解釋性高級語言,最大的特點是被稱為”膠水語言”。 一、簡單易學 Python的語法簡單易學,更加人性化,這使得它成為了初學者的入…

    編程 2025-04-29
  • Java Thread.start() 執行幾次的相關問題

    Java多線程編程作為Java開發中的重要內容,自然會有很多相關問題。在本篇文章中,我們將以Java Thread.start() 執行幾次為中心,為您介紹這方面的問題及其解決方案…

    編程 2025-04-29
  • OpenJudge答案1.6的C語言實現

    本文將從多個方面詳細闡述OpenJudge答案1.6在C語言中的實現方法,幫助初學者更好地學習和理解。 一、需求概述 OpenJudge答案1.6的要求是,輸入兩個整數a和b,輸出…

    編程 2025-04-29
  • Python爬蟲亂碼問題

    在網絡爬蟲中,經常會遇到中文亂碼問題。雖然Python自帶了編碼轉換功能,但有時候會出現一些比較奇怪的情況。本文章將從多個方面對Python爬蟲亂碼問題進行詳細的闡述,並給出對應的…

    編程 2025-04-29
  • NodeJS 建立TCP連接出現粘包問題

    在TCP/IP協議中,由於TCP是面向字節流的協議,發送方把需要傳輸的數據流按照MSS(Maximum Segment Size,最大報文段長度)來分割成若干個TCP分節,在接收端…

    編程 2025-04-29
  • Python按位運算符和C語言

    本文將從多個方面詳細闡述Python按位運算符和C語言的相關內容,並給出相應的代碼示例。 一、概述 Python是一種動態的、面向對象的編程語言,其按位運算符是用於按位操作的運算符…

    編程 2025-04-29

發表回復

登錄後才能評論