PSP2.1 | Personal Software Process Stages | 預估耗時(分鐘) | 實際耗時(分鐘) |
---|---|---|---|
Planning | 計劃 | 15 | 20 |
• Estimate | • 估計這個任務須要多少時間 | 800 | 1000 |
Development | 開發 | 600 | 600 |
• Analysis | • 需求分析 (包括學習新技術) | 30 | 60 |
• Design Spec | • 生成設計文檔 | 20 | 30 |
• Design Review | • 設計複審 | 10 | 30 |
• Coding Standard | • 代碼規範 (爲目前的開發制定合適的規範) | 10 | 10 |
• Design | • 具體設計 | 30 | 40 |
• Coding | • 具體編碼 | 400 | 500 |
• Code Review | • 代碼複審 | 20 | 15 |
• Test | • 測試(自我測試,修改代碼,提交修改) | 60 | 45 |
Reporting | 報告 | 60 | 60 |
• Test Repor | • 測試報告 | 30 | 30 |
• Size Measurement | • 計算工做量 | 20 | 15 |
• Postmortem & Process Improvement Plan | • 過後總結, 並提出過程改進計劃 | 20 | 30 |
合計 | 1000 |
我經過網上查閱和詢問擔任擔任小學老師的姑姑瞭解到,小學三年級數學四則混合運算有以下的幾個特色:數組
說明你如何設計這個程序函數
寫出具體實現的步驟學習
public static double Operation(String[] OpeMarkStrNumber, String[] OpeNumber) { //首先遍歷一遍存儲運算符的數組,尋找到* /這種優先級較高的運算符,運算出結果,而後將運算過的符號與數值改成null,而後使用去除null的函數,去掉null數據 while(true) { int PMAmount = 0; for(int i = 0; i < OpeMarkStrNumber.length-1; i++) { if(OpeMarkStrNumber[i] == "*") { double ans = Double.parseDouble(OpeNumber[i]) * Double.parseDouble(OpeNumber[i+1]); OpeNumber[i] = String.valueOf(ans); OpeNumber[i+1] = null; OpeMarkStrNumber[i] = null; OpeNumber = RemoveNull(OpeNumber); OpeMarkStrNumber = RemoveNull(OpeMarkStrNumber); PMAmount++; break; }else if(OpeMarkStrNumber[i] == "/") { double ans = Double.parseDouble(OpeNumber[i]) / Double.parseDouble(OpeNumber[i+1]); OpeNumber[i] = String.valueOf(ans); OpeNumber[i+1] = null; OpeMarkStrNumber[i] = null; OpeNumber = RemoveNull(OpeNumber); OpeMarkStrNumber = RemoveNull(OpeMarkStrNumber); PMAmount++; break; } } if(PMAmount == 0) { break; } } return PlusMinus(OpeMarkStrNumber, OpeNumber); } public static double PlusMinus(String[] OpeMarkStrNumber, String[] OpeNumber) { //當乘除法被消除完以後,能夠依次運算加減法,最終得出結果 int PMmarkNo = 0; double ans = Double.parseDouble(OpeNumber[0]) ; while(true) { if(OpeMarkStrNumber[PMmarkNo] == "+") { ans = ans + Double.parseDouble(OpeNumber[PMmarkNo+1]); PMmarkNo++; }else if(OpeMarkStrNumber[PMmarkNo] == "-"){ ans = ans - Double.parseDouble(OpeNumber[PMmarkNo+1]); PMmarkNo++; }else if(OpeMarkStrNumber[PMmarkNo] == null){ return ans; } } } public static String[] RemoveNull(String[] target) { //去除null 函數,將數組中的null移動至數組後面 for(int i = 0; i < target.length; i++) { if(target[i] == null) { for(int j = i; j < target.length; j++) { if(j != target.length-1) { target[j] = target[j+1]; }else { target[j] = null; } } } } return target; }
```測試
請給出本次實驗使用的代碼規範:編碼
並人工檢查代碼是否符合規範設計
輸入5 3指針
(5)20-16-18/9=2.0調試
從剛看到題目時的不知所措,第一想法就是「我不會」,可是又想到這是一次結對做業,正所謂三個臭皮匠勝過諸葛亮,兩個「臭皮匠"來解決這個三年級四則運算應該也綽綽有餘了吧,經過相互間的討論,解決了一些數組的越界,以及空指針的錯誤,節約了一些修改BUG的時間,對於不會的東西勤百度,這是解決問題的途徑之一。日誌