亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? piview.cpp

?? 用Visual C++開發的圖形化圓周率Pi計算程序
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// PiView.cpp : implementation of the CPiView class
//

#include "stdafx.h"
#include "Pi.h"

#include "PiDoc.h"
#include "PiView.h"

/////////////////////////////////////////////////////////////////////////////
//自定義頭文件
#include "stdio.h"
#include "string.h"
#include "stdlib.h"
#include "memory.h"
#include "NumSet.h"
/////////////////////////////////////////////////////////////////////////////

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CPiView

IMPLEMENT_DYNCREATE(CPiView, CView)

BEGIN_MESSAGE_MAP(CPiView, CView)
	//{{AFX_MSG_MAP(CPiView)
	ON_COMMAND(ID_CALUCATE, OnCalucate)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CPiView construction/destruction

CPiView::CPiView()
{
	// TODO: add construction code here
/////////////////////////////////////////////////////////////////////////////
//變量初始化
	m_Flag=0;
	m_Count=0;
/////////////////////////////////////////////////////////////////////////////
}

CPiView::~CPiView()
{
}

BOOL CPiView::PreCreateWindow(CREATESTRUCT& cs)
{
	// TODO: Modify the Window class or styles here by modifying
	//  the CREATESTRUCT cs

	return CView::PreCreateWindow(cs);
}

/////////////////////////////////////////////////////////////////////////////
// CPiView drawing

void CPiView::OnDraw(CDC* pDC)
{
	CPiDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	// TODO: add draw code for native data here
	char str1[20]="有效位數:";
	char str2[20]="迭代次數:";
	char str3[20]="使用時間:";
	char str4[20];
	char str5[20];
	char str6[20];
////////////////////////////////////////////////////////////////////////
//顯示等待信息
	if(m_Flag==1)
		pDC->TextOut(20,20,"正在計算,請稍候...");

////////////////////////////////////////////////////////////////////////
//計算完成,顯示結果
	if(m_Flag==2)
	{
		double time=((double)m_time1)/1000.0;
		pDC->TextOut(20,20,"正在計算,請稍候...");
		_ltoa(m_Number,str4,10);
		_ltoa(m_Count,str5,10);
		gcvt(time,10,str6);
		strcat(str1,str4);
		strcat(str2,str5);
		strcat(str3,str6);
		strcat(str3,"秒");
		if(m_Count!=0)
		{
			pDC->TextOut(20,40,"計算結束!");
			pDC->TextOut(20,60,str1);
			pDC->TextOut(20,80,"計算方法:");
			pDC->TextOut(85,80,m_Method);
			pDC->TextOut(20,100,str2);
			pDC->TextOut(20,120,str3);
			pDC->TextOut(20,140,"已將計算結果導入\"圓周率π.txt\"文件中");
		}
	}
}

/////////////////////////////////////////////////////////////////////////////
// CPiView diagnostics

#ifdef _DEBUG
void CPiView::AssertValid() const
{
	CView::AssertValid();
}

void CPiView::Dump(CDumpContext& dc) const
{
	CView::Dump(dc);
}

CPiDoc* CPiView::GetDocument() // non-debug version is inline
{
	ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CPiDoc)));
	return (CPiDoc*)m_pDocument;
}
#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CPiView message handlers

void CPiView::OnCalucate() 
{
	// TODO: Add your command handler code here
/////////////////////////////////////////////////////////////////////////////
//初始化迭代次數
	m_Count=0;
	CNumSet NumberSet;

/////////////////////////////////////////////////////////////////////////////
//讀取精度,開始計算
	if(NumberSet.DoModal()==IDOK)
	{
		m_Flag=1;
		Invalidate();
		//獲得有效位數N
		m_Number=NumberSet.m_Number;
		//為保證計算準確性,實際結果的位數取為N+10
		m_Size=m_Number+10;
		//保存所選擇的計算方法
		m_Method=NumberSet.m_Method;
/////////////////////////////////////////////////////////////////////////////
//開辟存放空間,用于保存高精度計算結果
		m_Result=new char[m_Size];
		m_An=new char[m_Size];
		AfxMessageBox("初始化完成,按回車開始計算!",MB_OK,NULL);
		//讀取計算開始前的時間
		m_time1=GetCurrentTime();
/////////////////////////////////////////////////////////////////////////////
//開始計算
		if(NumberSet.m_Method==_T("反正切函數級數展開"))
			ArcTan();
		else if(NumberSet.m_Method==_T("反正弦函數級數展開"))
			ArcSin();
		else if(NumberSet.m_Method==_T("Marchin公式"))
			Marchin();
		else if(NumberSet.m_Method==_T("Shanks公式"))
			Shanks();
		else if(NumberSet.m_Method==_T("Gauss公式"))
			Gauss();
////////////////////////////////////////////////////////////////////////////
//計算結束,讀取當前時間,求得計算所用時間
		m_time2=GetCurrentTime();
		m_time1=m_time2-m_time1;
////////////////////////////////////////////////////////////////////////////
//將計算結果保存為文件
		FileSave();
////////////////////////////////////////////////////////////////////////////
//顯示完成消息
		m_Flag=2;
		Invalidate();
	}
}

/////////////////////////////////////////////////////////////////////////////
//反正切函數級數展開求π函數
void CPiView::ArcTan()
{
	long Flag=1;
	int Up=1,Down=3,Temp,Add;
/////////////////////////////////////////////////////////////////////////////
//設置求和初值
	for(int i=0; i<m_Size; i++)
	{			
		m_Result[i]=0;
		m_An[i]=0;
	}
	m_Result[1]=2;
	m_An[1]=2;

/////////////////////////////////////////////////////////////////////////////
//計算過程
	while(Flag)
	{
/////////////////////////////////////////////////////////////////////////////
//待加項m_An乘上新加入項的分母,即m_An*=Up;
		Add=0;
		for(int i=m_Size-1;i>0;i--)
		{
			Temp=m_An[i]*Up+Add;
			m_An[i]=Temp%10;
			Add=Temp/10;
		}
/////////////////////////////////////////////////////////////////////////////
//待加項m_An再除去新加入項的分子,即m_An/=Down;
		Add=0;
		for(i=0;i<m_Size;i++)
		{
			Temp=m_An[i]+Add*10;
			m_An[i]=Temp/Down;
			Add=Temp%Down;
		}
/////////////////////////////////////////////////////////////////////////////
//將m_An加入結果m_Result中,即m_Result+=m_An;
		Flag=0;
		for(i=m_Size-1;i>0;i--)
		{
			Temp=m_Result[i]+m_An[i];
			m_Result[i]=Temp%10;
			m_Result[i-1]+=Temp/10;
			//判斷當前的通項是否已經為0
			if(m_An[i]!=0)
				Flag=1;
		}
/////////////////////////////////////////////////////////////////////////////
//一次迭代完成,求下一次迭代的新加入項,并記錄迭代次數;
		Up++;
		Down+=2;
		m_Count++;
	}
	return;
}

/////////////////////////////////////////////////////////////////////////////
//反正弦函數級數展開求π函數
void CPiView::ArcSin()
{
	long Flag=1;
	int k=1,Temp,Add;
/////////////////////////////////////////////////////////////////////////////
//設置求和初值
	for(int i=0; i<m_Size; i++)
	{
		m_Result[i]=0;
		m_An[i]=0;
	}
	m_Result[1]=3;
	m_An[1]=3;

/////////////////////////////////////////////////////////////////////////////
//計算過程
	while(Flag)
	{
/////////////////////////////////////////////////////////////////////////////
//待加項m_An乘上新加入項的分母,即m_An*=k;
		Add=0;
		for(int i=m_Size-1;i>0;i--)
		{
			Temp=m_An[i]*k+Add;
			m_An[i]=Temp%10;
			Add=Temp/10;
		}
/////////////////////////////////////////////////////////////////////////////
//待加項m_An乘上新加入項的分母,即m_An*=k;
		Add=0;
		for(i=m_Size-1;i>0;i--)
		{
			Temp=m_An[i]*k+Add;
			m_An[i]=Temp%10;
			Add=Temp/10;
		}
/////////////////////////////////////////////////////////////////////////////
//待加項m_An再除去新加入項的分子,即m_An/=(k+1);
		Add=0;
		for(i=0;i<m_Size;i++)
		{
			Temp=m_An[i]+Add*10;
			m_An[i]=Temp/(k+1);
			Add=Temp%(k+1);
		}
/////////////////////////////////////////////////////////////////////////////
//待加項m_An再除去新加入項的分子,即m_An/=(4*(k+2));
		Add=0;
		for(i=0;i<m_Size;i++)
		{
			Temp=m_An[i]+Add*10;
			m_An[i]=Temp/(4*(k+2));
			Add=Temp%(4*(k+2));
		}
/////////////////////////////////////////////////////////////////////////////
//將m_An加入結果m_Result中,即m_Result+=m_An;
		Flag=0;
		for(i=m_Size-1;i>0;i--)
		{
			Temp=m_Result[i]+m_An[i];
			m_Result[i]=Temp%10;
			m_Result[i-1]+=Temp/10;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美日韩另类视频免费观看| 日韩欧美的一区二区| 欧美性猛片xxxx免费看久爱| 日韩欧美色综合| 专区另类欧美日韩| 久久激五月天综合精品| 国产成人免费av在线| 欧美精品丝袜中出| 亚洲精品国产第一综合99久久| 国内一区二区在线| 欧美一区二区三区免费| 亚洲男女一区二区三区| 国产凹凸在线观看一区二区| 51精品视频一区二区三区| 亚洲精品v日韩精品| 国产不卡视频一区二区三区| 欧美一个色资源| 午夜精品123| 91福利区一区二区三区| 国产精品美日韩| 国产精品一区二区三区99| 91精品国产欧美一区二区成人| 亚洲乱码国产乱码精品精的特点 | 成人黄页在线观看| 精品日韩一区二区| 老鸭窝一区二区久久精品| 678五月天丁香亚洲综合网| 一区二区三区毛片| 色综合久久中文综合久久牛| 国产精品女人毛片| 丁香天五香天堂综合| 久久久久9999亚洲精品| 国产精品亚洲一区二区三区在线 | 日韩精品免费视频人成| 欧美日韩成人综合| 性做久久久久久免费观看| 欧美日韩一区二区三区四区| 亚洲最快最全在线视频| 欧美日韩一区久久| 亚洲国产aⅴ天堂久久| 欧美日韩精品免费观看视频| 午夜影院在线观看欧美| 日韩视频在线永久播放| 精品一区二区三区在线播放视频 | 久久超碰97中文字幕| 日韩免费高清视频| 国产在线播精品第三| 久久久综合视频| 成人一区在线看| 亚洲男人天堂av网| 欧美区视频在线观看| 蜜臀精品一区二区三区在线观看| 日韩欧美一级二级| 丁香激情综合五月| 亚洲综合在线电影| 欧美精选一区二区| 国产一区二区三区免费看| 中文字幕精品三区| 欧美在线观看视频在线| 日韩黄色免费网站| 国产校园另类小说区| 91蜜桃免费观看视频| 亚洲成a人v欧美综合天堂下载| 日韩一区二区免费高清| 国产福利一区二区| 曰韩精品一区二区| 日韩精品一区在线观看| 成人午夜免费av| 亚洲444eee在线观看| 国产欧美一区二区精品婷婷| 91黄色免费看| 韩国精品主播一区二区在线观看| 中文字幕五月欧美| 91精品国产丝袜白色高跟鞋| 福利视频网站一区二区三区| 亚洲成人午夜电影| 欧美国产日韩亚洲一区| 欧美欧美午夜aⅴ在线观看| 激情偷乱视频一区二区三区| 亚洲三级在线免费| 亚洲精品在线三区| 欧美在线一二三| 成人毛片在线观看| 免费一级片91| 亚洲一区在线观看免费 | 国产一区二区三区综合| 亚洲精品免费播放| 久久久99久久精品欧美| 欧美视频一区在线观看| 成人午夜激情影院| 国产资源在线一区| 亚洲午夜av在线| √…a在线天堂一区| 欧美va亚洲va在线观看蝴蝶网| 欧美在线一区二区三区| 99热这里都是精品| 国产精品1区二区.| 日本美女视频一区二区| 一区二区三区在线视频观看58 | 欧美日韩国产乱码电影| 成人av在线播放网址| 经典一区二区三区| 天天做天天摸天天爽国产一区| 中文字幕一区二区三区四区不卡| 久久久久久久性| 精品国产免费视频| 日韩一区二区电影在线| 精品视频一区二区不卡| 色综合天天做天天爱| 不卡影院免费观看| 粉嫩欧美一区二区三区高清影视| 极品瑜伽女神91| 九九视频精品免费| 蜜桃视频在线观看一区| 亚洲va国产天堂va久久en| 亚洲一区二区三区四区五区黄 | 青青草伊人久久| 亚洲第一成年网| 亚洲午夜视频在线观看| 一区二区视频在线看| 一区二区成人在线视频 | 中文字幕在线一区免费| 日本一区二区高清| 国产精品美女久久福利网站| 国产精品区一区二区三区| 欧美激情一区二区| 亚洲欧美乱综合| 亚洲国产欧美在线| 日韩精品视频网站| 久久精品久久99精品久久| 精品一区二区在线免费观看| 国产在线精品一区二区三区不卡| 国产精品自产自拍| 91色综合久久久久婷婷| 色域天天综合网| 91精品国产综合久久精品性色| 日韩一区二区在线看| 久久精品水蜜桃av综合天堂| 国产精品久久久久久久久久免费看| 中文字幕一区二区三区四区不卡 | 激情五月激情综合网| 丁香激情综合国产| 在线观看91视频| 日韩精品一区二区三区三区免费| 久久综合资源网| 国产精品久久久久久久久久久免费看| 亚洲六月丁香色婷婷综合久久 | 日韩亚洲电影在线| 国产欧美日韩激情| 亚洲一区日韩精品中文字幕| 日韩精品一区第一页| 国产成a人亚洲精品| 欧美中文字幕一区| 久久一夜天堂av一区二区三区 | 一本色道亚洲精品aⅴ| 欧美日韩在线播放一区| 久久先锋影音av鲁色资源网| 亚洲四区在线观看| 日本aⅴ免费视频一区二区三区| 国产精品996| 欧美日韩三级一区| 欧美经典一区二区三区| 午夜久久福利影院| 不卡视频免费播放| 欧美成人猛片aaaaaaa| 亚洲三级在线观看| 国产一区二区三区久久久| 色国产精品一区在线观看| 久久久久久久综合狠狠综合| 亚洲成人一区在线| av一区二区三区黑人| 日韩欧美一二区| 亚洲不卡av一区二区三区| 成人高清在线视频| 精品久久久久久亚洲综合网| 亚洲欧美福利一区二区| 国产成人午夜99999| 91麻豆精品久久久久蜜臀| 亚洲日本在线天堂| 国产乱码精品一区二区三| 91精品国产综合久久香蕉的特点| 最新不卡av在线| 福利一区福利二区| 国产亚洲精品中文字幕| 青椒成人免费视频| 欧美老女人第四色| 亚洲激情自拍偷拍| 91丨国产丨九色丨pron| 国产人妖乱国产精品人妖| 激情五月婷婷综合网| 日韩精品中文字幕在线不卡尤物| 亚洲不卡一区二区三区| 欧美午夜一区二区三区免费大片| 亚洲欧美另类小说视频| av成人免费在线| 中文字幕中文乱码欧美一区二区| 成人午夜电影网站| 欧美国产日韩亚洲一区| 成人av电影免费在线播放| 国产欧美视频在线观看|