




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、作品:科學(xué)計(jì)算器 作者:歐宗龍編寫(xiě)環(huán)境:vc+6.0語(yǔ)言:c#include "stdafx.h"#include <stdio.h>#include <windows.h>#include <windowsx.h>#include "resource.h"#include "MainDlg.h"#include <math.h>#include <string.h>#define PI 3.141593BOOL A_Op=FALSE;BOOL WINAPI Main_Pro
2、c(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam) switch(uMsg) HANDLE_MSG(hWnd, WM_INITDIALOG, Main_OnInitDialog); HANDLE_MSG(hWnd, WM_COMMAND, Main_OnCommand);HANDLE_MSG(hWnd,WM_CLOSE, Main_OnClose); return FALSE;BOOL Main_OnInitDialog(HWND hwnd, HWND hwndFocus, LPARAM lParam) return TRUE;void
3、TrimNumber(char a)/判斷并刪除小數(shù)點(diǎn)后無(wú)用的零for(unsigned i=0;i<strlen(a);i+)if(ai='.')for(unsigned j=strlen(a)-1;j>=i;j-)if(aj='0')aj='0'else if(aj='.')aj='0'else break;double Operate(char Operator,double n1,double n2) /判斷符號(hào),進(jìn)行相應(yīng)的運(yùn)算 if(Operator='0')if(Operat
4、or='+')n2+=n1;if(Operator='-')n2=n1-n2;if(Operator='*')n2*=n1;if(Operator='/')n2=n1/n2;if(Operator='')n2=pow(n1,n2);returnn2;/void IntBinary(char a,int n) if(n>1)IntBinary(a,n/2); sprintf(a,"%s%i",a,n%2);void decimal(char a,double m) if(m>0.000
5、001) m=m*2; sprintf(a,"%s%d",a,(long)m); decimal(a,m-(long)m); void Binary(char a,double Num)char DecP256=""double x,y;double *iptr=&y;x=modf(Num,iptr);decimal(DecP,x);IntBinary(a,(int)y);strcat(a,".");strcat(a,DecP);/void Main_OnCommand(HWND hwnd, int id, HWND hwnd
6、Ctl, UINT codeNotify)static DELTIMES=0;static char str256;static char Operator='0'static double RNum3; switch(id) case IDC_BUTTONN1:/數(shù)字1if(A_Op)SetDlgItemText(hwnd,IDC_EDIT,NULL);GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);strcat(str,"1"); SetDlgItemText(hwnd,IDC_EDIT,str);RNum1=a
7、tof(str);A_Op=FALSE;break;case IDC_BUTTONN2:/數(shù)字2if(A_Op)SetDlgItemText(hwnd,IDC_EDIT,NULL);GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);strcat(str,"2"); SetDlgItemText(hwnd,IDC_EDIT,str);RNum1=atof(str);A_Op=FALSE;break;case IDC_BUTTONN3:/數(shù)字3if(A_Op)SetDlgItemText(hwnd,IDC_EDIT,NULL);GetDl
8、gItemText(hwnd,IDC_EDIT,str,sizeof(str);strcat(str,"3"); SetDlgItemText(hwnd,IDC_EDIT,str);RNum1=atof(str);A_Op=FALSE;break;case IDC_BUTTONN4:/數(shù)字4if(A_Op)SetDlgItemText(hwnd,IDC_EDIT,NULL);GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);strcat(str,"4"); SetDlgItemText(hwnd,IDC_EDIT,
9、str);RNum1=atof(str);A_Op=FALSE;break;case IDC_BUTTONN5:/數(shù)字5if(A_Op)SetDlgItemText(hwnd,IDC_EDIT,NULL);GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);strcat(str,"5"); SetDlgItemText(hwnd,IDC_EDIT,str);RNum1=atof(str);A_Op=FALSE;break;case IDC_BUTTONN6:/數(shù)字6if(A_Op)SetDlgItemText(hwnd,IDC_EDIT
10、,NULL);GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);strcat(str,"6"); SetDlgItemText(hwnd,IDC_EDIT,str);RNum1=atof(str);A_Op=FALSE;break;case IDC_BUTTONN7:/數(shù)字7if(A_Op)SetDlgItemText(hwnd,IDC_EDIT,NULL);GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);strcat(str,"7"); SetDlgItemText(hw
11、nd,IDC_EDIT,str);RNum1=atof(str);A_Op=FALSE;break;case IDC_BUTTONN8:/數(shù)字8if(A_Op)SetDlgItemText(hwnd,IDC_EDIT,NULL);GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);strcat(str,"8"); SetDlgItemText(hwnd,IDC_EDIT,str);RNum1=atof(str);A_Op=FALSE;break;case IDC_BUTTONN9:/數(shù)字9if(A_Op)SetDlgItemText(h
12、wnd,IDC_EDIT,NULL);GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);strcat(str,"9"); SetDlgItemText(hwnd,IDC_EDIT,str);RNum1=atof(str);A_Op=FALSE;break;case IDC_BUTTONN0:/數(shù)字0if(A_Op)SetDlgItemText(hwnd,IDC_EDIT,NULL);GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);strcat(str,"0"); SetDl
13、gItemText(hwnd,IDC_EDIT,str);RNum1=atof(str);A_Op=FALSE;break;case IDC_BUTTONDEL:/小數(shù)點(diǎn).delif(A_Op)SetDlgItemText(hwnd,IDC_EDIT,NULL);GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);if(DELTIMES=0) strcat(str,".");DELTIMES+; SetDlgItemText(hwnd,IDC_EDIT,str);A_Op=FALSE;break;case IDC_BUTTONADD:
14、/加法運(yùn)算RNum1=atof(str);RNum0=RNum1;RNum1=RNum2;RNum2=Operate(Operator,RNum1,RNum0);sprintf(str,"%f",RNum2);TrimNumber(str);SetDlgItemText(hwnd,IDC_EDIT,str);Operator='+'DELTIMES=0;A_Op=TRUE;break;case IDC_BUTTONSUB: /減法運(yùn)算RNum1=atof(str);RNum0=RNum1;RNum1=RNum2;RNum2=Operate(Operator,
15、RNum1,RNum0);sprintf(str,"%f",RNum2);TrimNumber(str);SetDlgItemText(hwnd,IDC_EDIT,str);DELTIMES=0;A_Op=TRUE;Operator='-'break;case IDC_BUTTONMUL: /乘法運(yùn)算RNum1=atof(str);RNum0=RNum1;RNum1=RNum2;RNum2=Operate(Operator,RNum1,RNum0);sprintf(str,"%f",RNum2);TrimNumber(str);SetDl
16、gItemText(hwnd,IDC_EDIT,str);Operator='*'DELTIMES=0;A_Op=TRUE;break;case IDC_BUTTONDIV: /除法運(yùn)算RNum1=atof(str);RNum0=RNum1;RNum1=RNum2;RNum2=Operate(Operator,RNum1,RNum0);sprintf(str,"%f",RNum2);TrimNumber(str);SetDlgItemText(hwnd,IDC_EDIT,str);Operator='/'DELTIMES=0;A_Op=TRU
17、E;break;case IDC_BUTTONXY:/x的y次方GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);RNum1=atof(str);RNum0=RNum1;RNum1=RNum2;RNum2=Operate(Operator,RNum1,RNum0);sprintf(str,"%f",RNum2);TrimNumber(str);SetDlgItemText(hwnd,IDC_EDIT,str);Operator=''DELTIMES=0;break;case IDC_BUTTONPI: /圓周率PI,弧
18、度GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);if(atof(str)!=0)RNum2=atof(str)*PI;sprintf(str,"%f",RNum2);TrimNumber(str);SetDlgItemText(hwnd,IDC_EDIT,str);elsesprintf(str,"%f",PI);SetDlgItemText(hwnd,IDC_EDIT,str);A_Op=TRUE;break;case IDC_BUTTONSQRT: /開(kāi)根號(hào)GetDlgItemText(hwnd,IDC_E
19、DIT,str,sizeof(str);RNum2=sqrt(atof(str);sprintf(str,"%f",RNum2);TrimNumber(str);SetDlgItemText(hwnd,IDC_EDIT,str);A_Op=TRUE;break;case IDC_BUTTONSIN: /三角函數(shù)sin函數(shù)GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);RNum2=sin(atof(str);sprintf(str,"%f",RNum2);TrimNumber(str);SetDlgItemText
20、(hwnd,IDC_EDIT,str);A_Op=TRUE;break;case IDC_BUTTONCOS:/三角函數(shù)cos函數(shù)GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);RNum2=cos(atof(str);sprintf(str,"%f",RNum2);TrimNumber(str);SetDlgItemText(hwnd,IDC_EDIT,str);A_Op=TRUE;break;case IDC_BUTTONTAN:/三角函數(shù)tan函數(shù)GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(s
21、tr);RNum2=tan(atof(str);sprintf(str,"%f",RNum2);TrimNumber(str);SetDlgItemText(hwnd,IDC_EDIT,str);A_Op=TRUE;break;case IDC_BUTTONSQ: /平方GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);RNum2=atof(str)*atof(str);sprintf(str,"%f",RNum2);TrimNumber(str);SetDlgItemText(hwnd,IDC_EDIT,str)
22、;A_Op=TRUE;break;case IDC_BUTTONCUBE:/三次方GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);RNum2=atof(str)*atof(str)*atof(str);sprintf(str,"%f",RNum2);TrimNumber(str);SetDlgItemText(hwnd,IDC_EDIT,str);A_Op=TRUE;break;case IDC_BUTTONEX:/e的x次方GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);RNum2=exp
23、(atof(str);sprintf(str,"%f",RNum2);TrimNumber(str);SetDlgItemText(hwnd,IDC_EDIT,str);A_Op=TRUE;break;case IDC_BUTTON10X:/10的x次方GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);RNum2=pow(10,atof(str);sprintf(str,"%f",RNum2);TrimNumber(str);SetDlgItemText(hwnd,IDC_EDIT,str);A_Op=TRUE;b
24、reak;case IDC_BUTTONLN: /ln x GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);RNum2=log(atof(str);sprintf(str,"%f",RNum2);TrimNumber(str);SetDlgItemText(hwnd,IDC_EDIT,str);A_Op=TRUE;break;case IDC_BUTTONLOG10: /log10 GetDlgItemText(hwnd,IDC_EDIT,str,sizeof(str);RNum2=log10(atof(str);sprintf(str,"%f",RNum2);TrimNumber(str);SetDlgItemText(hwnd,IDC_EDIT,str);A_Op=TRUE;break;case IDC_BUTTONBINARY: /十進(jìn)制轉(zhuǎn)換為二進(jìn)制 char a256="
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 油脂管理制度
- 營(yíng)養(yǎng)學(xué)(師)考試歷年真題及答案
- 營(yíng)銷終端激勵(lì)方案
- 企業(yè)培訓(xùn)忠誠(chéng)課件
- 汽車零部件質(zhì)保及售后服務(wù)合同范本
- 車庫(kù)租賃及廣告位合作合同范本
- 橋梁電梯布置方案模板
- 綠色生態(tài)區(qū)個(gè)人商鋪?zhàn)赓U及環(huán)保要求合同
- 糞污設(shè)備安裝方案
- 高速鐵路拆除與路基改造施工服務(wù)合同
- 景區(qū)吊橋設(shè)施管理制度
- 供水水費(fèi)收繳管理制度
- 房產(chǎn)中介店經(jīng)營(yíng)管理制度
- 《2025版防范電信網(wǎng)絡(luò)詐騙宣傳手冊(cè)》專題講座
- 2025-2030年中國(guó)寫(xiě)字樓行業(yè)市場(chǎng)深度調(diào)研及前景趨勢(shì)與投資研究報(bào)告
- Q-GDW 10831.1-2025 飛行器展放初級(jí)導(dǎo)引繩施工工藝導(dǎo)則第1部分:多旋翼無(wú)人機(jī)
- 【伊春】2025年黑龍江伊春市紀(jì)委監(jiān)委所屬事業(yè)單位公開(kāi)招聘工作人員57人筆試歷年典型考題及考點(diǎn)剖析附帶答案詳解
- 2025年希望杯IHC真題-二年級(jí)(含答案)
- T/CNCA 039-2022車用甲醇汽油(M15)用改性甲醇
- MSDS-不銹鋼304介紹文檔
- 2025年非營(yíng)利組織運(yùn)營(yíng)師考試試題及答案詳解
評(píng)論
0/150
提交評(píng)論