TXT四則運算計算器

来源:http://www.cnblogs.com/yosha/archive/2016/03/13/5273266.html
-Advertisement-
Play Games

基本思想:使用getline函數從TXT文件中依次讀出中綴表達式,將其轉為尾碼表達式後計算結果,並與用戶結果比對。 整數、分數、小數的處理:將小數和整數都視為預設分母為1的分數.建立分數類,在中綴轉換成尾碼時將整數和小數轉換為分數. 關於求最大公約數所使用的輾轉相除法在上一篇博文中已經寫過。為了之後


基本思想:使用getline函數從TXT文件中依次讀出中綴表達式,將其轉為尾碼表達式後計算結果,並與用戶結果比對。

整數、分數、小數的處理:將小數和整數都視為預設分母為1的分數.建立分數類,在中綴轉換成尾碼時將整數和小數轉換為分數.

class Fenshu
{
    private:
        int fz;
        int fm;
    public:
        int getfz(){
        return fz;
        }
        int getfm(){
        return fm;
        }
        void setfz(int FZ){
        fz=FZ;
        }
        void setfm(int FM){
        if(FM!=0)
            fm=FM;
        else
            cout<<"分母不能為0\n";
        }
         Fenshu(){
        fz=-1;
        fm=-1;
        }
         Fenshu(int a,int b){
        fz=a;
        if(b!=0)
            fm=b;
        else cout<<"分母不能為0\n";
        }

         int gcd(int a, int b)//求最大公約數
        {
            if(b == 0)
                return a;
            return gcd(b, a % b);
        }
         
         void yuefen(){//約分
             int Gcd=1;
            Gcd=gcd(fz,fm);
            //cout<<"GCD:"<<Gcd<<endl;
            fz=fz/Gcd;
            fm=fm/Gcd;
    //        cout<<"results:";show();//test
         }

         Fenshu operator+(Fenshu F)
         {
             return Fenshu(fz*F.fm+F.fz*fm,fm*F.fm);
         }
          Fenshu operator-(Fenshu F)
         {
             return Fenshu(fz*F.fm-F.fz*fm,fm*F.fm);
         }
          Fenshu operator*(Fenshu F)
         {
             return Fenshu(fz*F.fz,fm*F.fm);
         }
         Fenshu operator/(Fenshu F)
         {
             return Fenshu(fz*F.fm,fm*F.fz);
         }
         void show(){
         cout<<fz<<"/"<<fm<<endl;
         }
};

關於求最大公約數所使用的輾轉相除法在上一篇博文中已經寫過。為了之後代碼書寫方便,使用了重載。

中綴轉換成尾碼的處理:使用棧作為數據結構.

template <class ElemType> class MyStack
{
public:
    const static  int MAXSIZE =100;
    ElemType data[MAXSIZE];
    int top;//棧頂腳標

public:
    void init();            // 初始化棧
    bool empty();            // 判斷棧是否為空
    ElemType gettop();        // 讀取棧頂元素(不出)
    void push(ElemType x);    // 進棧
    ElemType pop();            // 出棧
};

 

 

遇到的問題:

1.分數類定義是分子和分母作為int型變數,題目中出現的小數不能運算;

分析:要將小數轉換成可存進分數的整數,小數點後每有一位,分子分母同乘10,

// 將數字字元串轉變成相應的數字
Fenshu read_number(char str[],int *i)
{
    Fenshu x(0,1);
    int k = 0;
    while(str[*i] >='0' && str[*i]<='9')  // 處理整數部分
    {
        x.setfz(x.getfz()*10+(str[*i]-'0') );
        (*i)++;
    }

    if(str[*i]=='.') // 處理小數部分
    {
        (*i)++;
        while(str[*i] >= '0'&&str[*i] <='9')
        {
            x.setfz(x.getfz()*10+(str[*i]-'0'));
            x.setfm(x.getfm()*10);
            (*i)++;
            k++;
        }
    }
    return x;
}

 

2.對於存在負號'-'的題目提示棧為空;

分析:負號與減號的字元同為'-',導致在中綴轉尾碼時負號與減號進行了相同的操作(彈出兩個棧頂的操作數)導致操作數錯誤操作;

解決方法:找出作為負號使用的'-',轉換時替換成別的符號寫入尾碼表達式.計算尾碼表達式時,將該符號後的數字作為0的減數壓入棧

//修正負號的場合
             if (pre[i]=='-')    // 負號使用場合
            {
                if(pre[i-1]<'0' || pre[i-1]>'9' || pre[i-1]=='(' || i==0)
                {
                    post[j++]='_';
                    i++;
                    continue;
                }
            }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • C語言形式參數和實際參數的概念和在一個函數中交換外部變數的方法介紹
  • 關於Android Develop 文檔明明本地下載了,但在瀏覽器里打開還是很卡,原因是html文檔中有鏈接Google伺服器的Link和script。 網上有很多解決方案,其中一種是刪除裡面所有鏈接Google伺服器的Link和script。 我在網上下載的JAVA代碼這兩行修飾css代碼是怎麼也
  • atitit.RandomAccessFile rws rwd 的區別於聯繫   1. Rw rws  rwd1 2. "rws" 模式1 3. rwd"模式2       "r"    以只讀方式打開。調用結果對象的任何 write 方法都將導致拋出 IOException。  "rw" 
  • 要深入瞭解ClassLoader,首先就要知道ClassLoader是用來乾什麼的,顧名思義,它就是用來載入Class文件到JVM,以供程式使用 的。我們知道,java程式可以動態載入類定義,而這個動態載入的機制就是通過ClassLoader來實現的,所以可想而知ClassLoader的重 要性如何
  • 初學JAVA做一些總結,有說的不對的地方希望大家多多指教。 如果能給同樣帶有迷惑的同學帶來幫助,是很開森的一件事情。 剛學JAVA的時候肯定會碰到這三個環境變數的設定,往往總是知其然不知其所以然, 按照說明做完了卻不知道為什麼這麼做,這裡簡單做一些總結說明。 首先,什麼是環境變數 環境變數是指在操作...
  •        參考文檔:              1、金角大王博客:http://www.cnblogs.com/alex3714/articles/5188179.html              2、銀角大王博客:http://www.cnblogs.com/wupeiqi/articles
  • 1、 對JButton大小的設置        button.setPreferredSize(new Dimension(30,30));      //(30,30) 是你要設置按鈕的大小 2、 對JButton透明的設置       button.setContentAreaFilled(fa
  • 打包的意義: ①   標準Java庫是由一系列包組成,包括java.lang,java.util,java.net等。標準Java包就是層次型包結構,就如同硬碟上嵌套的子目錄一樣,我們可以使用嵌套層次結構來組成包; ②   Java的包是為了更好地規劃代碼,防止命名衝突和混亂。所以Java出現了打包
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...