C語言結(jié)課設(shè)計(jì)之計(jì)算器功能
更新時(shí)間:2020年02月28日 10:49:25 作者:長風(fēng)Qiu
這篇文章主要為大家詳細(xì)介紹了C語言結(jié)課設(shè)計(jì)之計(jì)算器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
本文實(shí)例為大家分享了C語言實(shí)現(xiàn)計(jì)算器的具體代碼,供大家參考,具體內(nèi)容如下
/*===============================================*\ ** 設(shè)計(jì)目的:簡單計(jì)算器,計(jì)算形如10*(20.2-30.6)+5.0/2的表達(dá)式值 ** 簡要原理:中綴式轉(zhuǎn)逆波蘭式(后綴式) ** IDE:Dev-Cpp 4.9.9.2 ** 注意事項(xiàng):括號(hào)必須是英文狀態(tài)的 ** 時(shí)間: 2014-6-17 \*===============================================*/ #include <stdio.h> #include <string.h> #include <stdlib.h> #define maxn 1000 char buf[maxn], str[maxn], signStack[maxn], ch[2]; int len, id, idSign, idAns, i, n; double ans[maxn]; void checkSign(char sign){ if(sign == '(') signStack[idSign++] = sign; else if(sign == '*' || sign == '/'){ while(idSign && (signStack[idSign-1] == '*' || signStack[idSign-1] == '/')) str[id++] = signStack[--idSign]; signStack[idSign++] = sign; }else if(sign == ')'){ while(signStack[idSign-1] != '(') str[id++] = signStack[--idSign]; --idSign; }else{ while(idSign && signStack[idSign-1] != '(') str[id++] = signStack[--idSign]; signStack[idSign++] = sign; } str[id++] = ' '; } int check(double a, char sign){ if(a == 0 && sign == '/'){ printf("除數(shù)不能為0!,程序結(jié)束。\n"); system("pause"); exit(EXIT_FAILURE); } return 1; } double cal(double a, double b, char sign){ switch(sign){ case '+': return a + b; case '-': return a - b; case '*': return a * b; case '/': return a / b; } } int main(){ printf("\t\t\t\t簡單計(jì)算器\n\n"); printf("\t\t ======================================\n"); printf("\t\t || 支持+ - * / ( ) 等符號(hào)和負(fù)數(shù)輸入 ||\n"); printf("\t\t ======================================\n"); printf("\t\t\t\t\t\t原創(chuàng)作者:邱正鋼\n"); printf("\t\t\t\t\t\t完成時(shí)間:2014年6月17日\n"); printf("\t\t\t\t\t\tEmail:2276479303@qq.com\n"); printf("請輸入一個(gè)表達(dá)式,如 -10*(20.2-30.6)+5.0/2\n以回車結(jié)束:\n"); do{ gets(buf); id = idSign = idAns = 0; if((len = strlen(buf)) == 0) continue; int flag = 0; //這個(gè)是用來判斷'-'字符是負(fù)號(hào)還是減號(hào)的。1表示數(shù)字,0表示 +*/( /*判斷原理:如果第一次讀取就碰到-,那么一定是負(fù)號(hào),若最近一次讀取是+*-/(那么 也一定是負(fù)號(hào),如果是右括號(hào)或數(shù)字那么是減號(hào)*/ for(i = 0; i < len; ++i){ if(buf[i] == ' ') continue; if(buf[i] >= '0' && buf[i] <= '9' || buf[i] == '.' || buf[i] == '-' && !flag){ str[id++] = buf[i]; flag = 1; } else { str[id++] = ' '; checkSign(buf[i]); if(buf[i] != ')') flag = 0; else flag = 1; } } while(idSign) str[id++] = signStack[--idSign]; for(i = 0, n = 0; i < id; ++i){ if(str[i] == ' ') continue; /*用增加空格的方式判斷‘-'字符是負(fù)號(hào)還是減號(hào),若‘-'后面挨著數(shù)字或小數(shù)點(diǎn),那么一定是負(fù)號(hào)*/ if(str[i] >= '0' && str[i] <= '9' || str[i] == '.' || str[i] == '-' && (str[i+1] >= '0' && str[i+1] <= '9' || str[i+1] == '.')){ sscanf(str + i, "%lf%n", &ans[idAns++], &n); i += n - 1; continue; }else if(check(ans[idAns-1], str[i])){ ans[idAns-2] = cal(ans[idAns-2], ans[idAns-1], str[i]); --idAns; } } printf("結(jié)果是 %.2lf\n", ans[0]); printf("輸入Y 繼續(xù), N 退出: "); scanf("%s", ch); }while(ch[0] == 'Y' || ch[0] == 'y'); printf("感謝您的使用!再見\n"); system("pause"); return 0; }
關(guān)于計(jì)算器的精彩文章請查看《計(jì)算器專題》 ,更多精彩等你來發(fā)現(xiàn)!
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- C語言實(shí)現(xiàn)簡單計(jì)算器程序
- C語言數(shù)據(jù)結(jié)構(gòu)之簡易計(jì)算器
- C語言實(shí)現(xiàn)簡單計(jì)算器功能(1)
- C語言實(shí)現(xiàn)簡單的計(jì)算器
- C語言實(shí)現(xiàn)簡單計(jì)算器功能(2)
- C語言實(shí)現(xiàn)簡單計(jì)算器
- 用C語言實(shí)現(xiàn)計(jì)算器功能
- C語言實(shí)現(xiàn)個(gè)稅計(jì)算器
- C語言運(yùn)用函數(shù)指針數(shù)組實(shí)現(xiàn)計(jì)算器功能
- 用C語言實(shí)現(xiàn)簡單的計(jì)算器功能
相關(guān)文章
Qt線程QThread開啟和安全退出的實(shí)現(xiàn)
本文主要介紹了Qt線程QThread開啟和安全退出的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06C++實(shí)現(xiàn)簡單插件機(jī)制原理解析
這篇文章主要介紹了C++實(shí)現(xiàn)簡單插件機(jī)制原理解析,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02C語言實(shí)現(xiàn)選擇排序、直接插入排序、冒泡排序的示例
這篇文章主要介紹了C++實(shí)現(xiàn)選擇排序、直接插入排序、冒泡排序的代碼示例,相當(dāng)簡潔直觀,也是算法和數(shù)據(jù)結(jié)構(gòu)學(xué)習(xí)中的基礎(chǔ),需要的朋友可以參考下2016-02-02