棧和隊列的應用-計算器實例

‘’‘
(11 + 3)× 2 -5
順序存儲棧來實現
’‘’
sqstack.h

#ifndef SQSTACK_H__
#define SQSTACK_H__
#define MAXSIZE	 32	
typedef int datatype typedef struct node_st 
{datatype data[MAXSIZE];	int top;}sqstack;sqstack *st_create(void);
int st_isempty(sqstack *);
int st_push(sqstack *,datatype *);
int st_pop(sqstack *,datatype *);
int st_top(sqstack *,datatype *);
void st_travel(sqstack *);
void st_destory(sqstack *);#endif

sqstack.c

#include<stdio.h>
#include<stdlib.h>#include"sqstack.h"sqstack *st_create(void)
{sqstack *st;st = malloc(sizeof(*st));if(st == NULL)return NULL;st->top = -1;return st;
}int st_isempty(sqstack *st)
{return (st->top == -1);
}int st_push(sqstack *st,datatype *data)
{if(st->top == MAXSIZE -1)return -1;st->data[++st->top] = *data;return 0;
}int st_pop(sqstack *st,datatype *data)
{if(st_isempty(st))return -1;*data = st->data[st->top--];return 0;}int st_top(sqstack *st,datatype *data)
{if(st_isempty(st))return -1;*data = st->data[st->top];return 0;
}void st_travel(sqstack *st)
{	int i;if(st_isempty(st))return ;for(i = 0; i < st->top;i++)printf("%d ",st->data[i]);printf("\n");
}void st_destory(sqstack *st)
{free(st);
}

main.c

#include<stdio.h>
#include<stdlib.h>#include"sqstack.h"void compute(sqsatck *snum,datatype *op)
{datatype n1,n2,n;st_pop(snum,&n2);st_pop(snum,&n1);switch(*op){	case '+':n = n1+n2;break;case '-':n = n1-n2;break;case '*':n = n1*n2;break;case '/':n = n1/n2;break;default:exit(1);}st_push(snum,&n);}
static void deal_bracket(sqstack *snum,sqstack *sop)
{datatype old_op;st_top(sop,&old_op);while(old_op != '('){st_pop(sop,&old_op);compute(snum,&old_op);st_top(sop,&old_op);}st_pop(sop&old_op);
}
static int get_pri(int op)
{switch(op){case '(':return 0;case '+':case '-':return 1;case '*':case '/':return 2;default:return -1;}}static void deal_op(sqstack *snum,sqstack *sop,int op)
{datatype old_op;if(st_isempty(sop) || op == '('){st_push(sop,&op);return ;}st_top(sop,&old_op);if(get_pri(op) > get_pri(old_op)){st_push(sop,&op);return ;}while(get_pri(op) <= get_pri(old_op)){st_pop(sop,&old_op);computer(snum,&old_op);if(st_isempty(sop))break;		st_top(sop,&old_op)}st_push(sop,&op);
}int main()
{int i =0;char str[]="(11+3)*2-5";sqstack *snum,*sop;int value = 0;int flag = 0;snum = st_create();if(sum == NULL)exit(1);sop = st_create();if(sop == NULL)exit(1);while(str[i] != '\0'){if(str[i] > '0' && str[i] < '9'){value = value *10 + (str[i] - '0');flag = 1;}else{if(flag){st_push(snum,&value);flag = 0;value = 0;}if(str[i] == ')'){deal_bracket(snum,sop);}else{deal_op(snum,sop,str[i]);}}i++;}if(flag)st_push(snum,&value);while(!st_isempty(sop)){	datatype old_op;st_pop(sop,&old_op);computer(snum,&old_op);}st_travel(snum);st_destory(snum);st_destroy(sop);exit(0);
}

Makefile

all:sqstacksqstack:sqstack.o main.o$(CC) $^ -o $@clean:rm sqstack *.o -rf

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/15456.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/15456.shtml
英文地址,請注明出處:http://en.pswp.cn/web/15456.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

閑話 .NET(5):.NET Core 有什么優勢?

前言 .NET Core 并不是 .NET FrameWork 的升級版&#xff0c;它是一個為滿足新一代的軟件設計要求而從頭重新開發的開發框架和平臺&#xff0c;所以它沒有 .NET FrameWork 的歷史包袱&#xff0c;相對于 .NET FrameWork&#xff0c;它具備很多優勢。 .NET Core 有哪些優勢&am…

智算中心帶寬漫談 -- 開篇

隱秘的角落 帶寬對高性能計算是一個永恒的話題&#xff0c;本質上&#xff0c;帶寬即數據交換的速率&#xff0c;單位時間的傳輸數據越多&#xff0c;帶寬就越高&#xff0c;但對高性能計算來說&#xff0c;對高帶寬的渴求永無止境&#xff0c;好比宏觀現實世界中的車道&#…

QT實現線程的四種方式(QThread、QRunnable和QThreadPool、QObject、QtConcurrent)

在當今高性能計算需求日益增長的背景下,多線程編程已成為提升應用性能的重要手段。Qt框架,作為一個功能全面、跨平臺的C++應用程序開發工具包,為我們提供了多種多線程實現方案。本文將介紹QThread類在Qt多線程編程中的應用,以及如何通過QRunnable和QThreadPool、QObject的m…

C# GDI+ 繪制文字不同的操作系統渲染文字大小不同

一、C# GDI 繪制文字不同的操作系統渲染文字大小不同 原因&#xff1a;使用Font 字體的時候&#xff0c;沒有指定字體渲染的單位。 不同系統的默認字體單位會不同。 二、解決方案&#xff1a; 在指定字體的時候&#xff0c;指定字體大小&#xff0c;同時也要設置字體的單位 …

sqlserver 創建表,列及表,列描述

-- 創建表 CREATE TABLE Employees (EmployeeID INT PRIMARY KEY,EmployeeName NVARCHAR(100),EmployeeEmail NVARCHAR(100) );-- 為表添加描述 EXEC sp_addextendedproperty name NMS_Description, value N員工信息表, level0type NSchema, level0name dbo, level1type N…

springboot整合kkFileView部署,前端使用

前言&#xff1a; 官方文檔&#xff1a;https://kkfileview.keking.cn/zh-cn/docs/production.html docker方式或加入星球獲取發行包直接獲取啟動&#xff0c;無需以下步驟&#xff1a; 拉取鏡像# 網絡環境方便訪問docker中央倉庫 docker pull keking/kkfileview:4.1.0# 網…

pytest框架的代碼如何用vscode進行debug

{"version": "0.2.0","configurations": [{"name": "Python: Run My Module", // 配置名稱&#xff0c;將在調試配置下拉列表中顯示"type": "debugpy", // 調試類型&#xff0c;這里是Python"requ…

二元關系表示

一、二元關系的定義和表示 什么是二元關系&#xff1f;對集合A和B&#xff0c;A\timesB的任意子集R為A到B的一個二元關系。當AB時&#xff0c;A\timesA的任一子集R稱為A上的一個二元關系。在不引起誤解的情況下&#xff0c;二元關系可簡稱關系。 若|A|m,|B|n&#xff0c;則A到…

常用字體映射字典

表格形式 英文字體名稱中文字體名稱SimSun宋體SimHei黑體KaiTi楷體FangSong仿宋YouYuan幼圓LiSu隸書NSimSun新宋體SimSun-ExtB宋體-ExtBFangSong_GB2312仿宋_GB2312KaiTi_GB2312楷體_GB2312Microsoft YaHei微軟雅黑Microsoft JhengHei微軟正黑體STXihei華文細黑STKaiti華文楷體…

手機版AI寫作軟件哪個好用?5款AI寫作軟件分享

在這個快節湊的時代&#xff0c;人們對于高效、便捷的創作方式很是追求。尤其是在人工智能技術發展迅速的今天&#xff0c;AI寫作軟件的出現&#xff0c;讓很多自媒體創作者都會想到在手機上面進內容創作&#xff0c;這樣不僅能提高工作效率&#xff0c;而且工作的自由度會更高…

自動化運維(AIOps): 現代IT管理的革命

在數字化時代&#xff0c;企業的 IT 系統變得愈加復雜。從云計算到大數據&#xff0c;從物聯網到人工智能&#xff0c;技術的飛速發展使得企業面臨前所未有的挑戰。這種復雜性不僅體現在數據量和數據流的增加上&#xff0c;還包括高成本和高錯誤率的運維需求。在此背景下&#…

基于51單片機的盆栽自動澆花系統

一.硬件方案 工作原理是濕度傳感器將采集到的數據直接傳送到ADC0832的IN端作為輸入的模擬信號。選用濕度傳感器和AD轉換&#xff0c;電路內部包含有濕度采集、AD轉換、單片機譯碼顯示等功能。單片機需要采集數據時&#xff0c;發出指令啟動A/D轉換器工作&#xff0c;ADC0832根…

Hive 變量定義與引用

文章目錄 1.背景2.Hive 變量命名空間查看變量設置變量引用變量 參考文獻 1.背景 在書寫 Hive SQL 時&#xff0c;有時需要將重復出現的值從 SQL 分離出來&#xff0c;以變量的方式表示和引用。 設置變量和引用變量可以帶來以下幾個好處&#xff1a; 簡化查詢語句&#xff1a;…

Android 實現豎排文本(垂直方向顯示)

Android 實現豎排文本-垂直方向顯示 前言效果圖代碼實現方式一 Custom View1. 自定義視圖 VerticalTextView2. 在xml布局文件中使用3. 設置文本內容 方式二 使用 TextView 的 rotation屬性方式三 使用帶有跨距文本的TextView1. 自定義視圖 VerticalTextView2. 在xml布局文件中使…

AI學習指南數學工具篇-凸優化基礎知識凸函數

AI學習指南數學工具篇-凸優化基礎知識凸函數 引言 在凸優化過程中&#xff0c;凸函數是一個非常重要的概念&#xff0c;它在機器學習、深度學習和優化算法中都有廣泛的應用。凸函數具有很多獨特的性質&#xff0c;能夠幫助我們更好地理解優化問題并且設計高效的優化算法。本文…

【Golang】Golang獲取Gin框架PostForm上傳的文件

文章目錄 前言一、函數解釋二、代碼實現三、總結 前言 在Web開發中&#xff0c;文件上傳是一項常見的功能。例如&#xff0c;用戶可能需要上傳頭像、文檔或其他類型的文件。在Go語言的Gin框架中&#xff0c;我們可以很方便地處理文件上傳。在這篇博客中&#xff0c;我將解釋如…

怎樣理解 Vue 的單項數據流

Vue 的單項數據流是一個核心概念&#xff0c;它指的是在 Vue 組件中&#xff0c;數據的流動方向是單向的&#xff0c;從父組件流向子組件。以下是關于 Vue 單項數據流的詳細理解&#xff1a; 數據流的方向&#xff1a; Vue 中的數據流動是單向的&#xff0c;即數據只能從父組件…

中國交通信息科技集團有限公司(中交信科)java開發工程師-機試題目/頌大技術面試總結/理工數傳 軟件開發一面二面面試總結/武漢智能視覺信息技術有限公司/高級

武漢智能視覺信息技術有限公司/高級 如果解決jvm內存溢出如果解決億級別的數據導出&#xff0c;有沒有其他的方案可以解決呢索引的原理工作中用了哪些索引提高了多少的速度線程池的創建方法--解釋new ThreadPool的其他參數以及四大拒絕策略分布式使用用到了哪些模式xxl-job的原…

pillow學習4

ImageChops 模塊 在 Pillow 庫的內置模塊 ImageChops 中包含了多個用于實現圖片合成的函數。這些合成 功能是通過計算通道中像素值的方式來實現的。其主要用于制作特效、合成圖片等操作。 常用的內置函數如下所示&#xff1a; &#xff08;1&#xff09;相加函數 add()&#xf…

【Windows系統】解決Intel 6代CPU安裝win7系統過程中無法操作鍵盤鼠標的問題

問題 微軟表示&#xff0c;從 2016 年 7 月 17 日起&#xff0c;新的 Intel、AMD 和Qualcomm 處理器將僅支持 Windows 10&#xff0c;不再支持 Windows 7 和 8.1。因此&#xff0c;Intel 6代以后的CPU因為沒有USB驅動無法完成win7系統的安裝。 下文核心思想是通過老毛桃PE系統…