欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言結(jié)課設(shè)計之計算器功能

 更新時間:2020年02月28日 10:49:25   作者:長風(fēng)Qiu  
這篇文章主要為大家詳細介紹了C語言結(jié)課設(shè)計之計算器功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了C語言實現(xiàn)計算器的具體代碼,供大家參考,具體內(nèi)容如下

/*===============================================*\
** 設(shè)計目的:簡單計算器,計算形如10*(20.2-30.6)+5.0/2的表達式值
** 簡要原理:中綴式轉(zhuǎn)逆波蘭式(后綴式)
** IDE:Dev-Cpp 4.9.9.2
** 注意事項:括號必須是英文狀態(tài)的 
** 時間: 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簡單計算器\n\n");
 printf("\t\t ======================================\n");
 printf("\t\t || 支持+ - * / ( ) 等符號和負數(shù)輸入 ||\n");
 printf("\t\t ======================================\n");
 printf("\t\t\t\t\t\t原創(chuàng)作者:邱正鋼\n");
 printf("\t\t\t\t\t\t完成時間:2014年6月17日\n");
 printf("\t\t\t\t\t\tEmail:2276479303@qq.com\n");
 
 printf("請輸入一個表達式,如 -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; //這個是用來判斷'-'字符是負號還是減號的。1表示數(shù)字,0表示 +*/(
 /*判斷原理:如果第一次讀取就碰到-,那么一定是負號,若最近一次讀取是+*-/(那么
 也一定是負號,如果是右括號或數(shù)字那么是減號*/
 
 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;
 /*用增加空格的方式判斷‘-'字符是負號還是減號,若‘-'后面挨著數(shù)字或小數(shù)點,那么一定是負號*/
 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)于計算器的精彩文章請查看《計算器專題》 ,更多精彩等你來發(fā)現(xiàn)!

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 用C語言實現(xiàn)掃雷小程序

    用C語言實現(xiàn)掃雷小程序

    這篇文章主要為大家詳細介紹了用C語言實現(xiàn)掃雷小程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • Qt線程QThread開啟和安全退出的實現(xiàn)

    Qt線程QThread開啟和安全退出的實現(xiàn)

    本文主要介紹了Qt線程QThread開啟和安全退出的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • C語言逆向分析語法超詳細分析

    C語言逆向分析語法超詳細分析

    這篇文章主要介紹了C語言逆向分析語法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-11-11
  • 如何通過指針突破C++類的訪問權(quán)限

    如何通過指針突破C++類的訪問權(quán)限

    這篇文章主要介紹了通過指針突破C++類的訪問權(quán)限,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02
  • C++實現(xiàn)簡單插件機制原理解析

    C++實現(xiàn)簡單插件機制原理解析

    這篇文章主要介紹了C++實現(xiàn)簡單插件機制原理解析,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-02-02
  • C語言實現(xiàn)選擇排序、直接插入排序、冒泡排序的示例

    C語言實現(xiàn)選擇排序、直接插入排序、冒泡排序的示例

    這篇文章主要介紹了C++實現(xiàn)選擇排序、直接插入排序、冒泡排序的代碼示例,相當(dāng)簡潔直觀,也是算法和數(shù)據(jù)結(jié)構(gòu)學(xué)習(xí)中的基礎(chǔ),需要的朋友可以參考下
    2016-02-02
  • C++右值引用問題解決

    C++右值引用問題解決

    本文主要介紹了C++右值引用問題解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • C語言通訊錄實例分享

    C語言通訊錄實例分享

    這篇文章主要為大家分享了C語言通訊錄實例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-02-02
  • KMP算法最淺顯理解(小白教程)

    KMP算法最淺顯理解(小白教程)

    這篇文章主要介紹了KMP算法最淺顯理解(小白教程),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • C++ Primer Plus詳解

    C++ Primer Plus詳解

    這篇文章主要為大家詳細介紹了C++ Primer Plus,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02

最新評論