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

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

?? calculate.cpp

?? 24點游戲,用c++實現
?? CPP
字號:
// Caculate.cpp: implementation of the CCalculate class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include <math.h>
#include "Calculate.h"

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

#define MAXPRIORITY 4    //優先級

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

IMPLEMENT_SERIAL(CCalculate, CObject, 0)//序列化
CCalculate::CCalculate()
{
	m_nPos=0;
	m_pRoot=NULL;
	m_strExpression="0";
	m_strWrongMessage="";
	m_bIsValid=FALSE;
}

CCalculate::CCalculate(const CString& strExpression)
{
//	m_strStep=strExpression;
	m_strExpression=strExpression+'\0'+'\0';
	m_strExpression.Replace(" ","");
	m_nPos=0;
	m_pRoot=NULL;
	m_strWrongMessage="";
	m_bIsValid=FALSE;
}

CCalculate::~CCalculate()
{
	FreeTree(m_pRoot);

}

void CCalculate::FreeTree(CNode* nod)
{//釋放樹節點
	if (nod==NULL) return;
	if (nod->left!=NULL) FreeTree(nod->left);
	if (nod->right!=NULL) FreeTree(nod->right);
	delete nod;
}

//生成一個樹
int CCalculate::MakeTree()
{
	//表達式為空
	if (m_strExpression.IsEmpty())
		return 0;

	
	FreeTree(m_pRoot); // Eliberarea memoriei ocupate de arbore
	
	m_pRoot = NULL;
	m_nPos = 0;//m_nPos為結點在樹中的編號
	m_pRoot = AddSub();
	if (m_strExpression[m_nPos]!='\0'||!m_strWrongMessage.IsEmpty()) 
	{
		if(m_strWrongMessage.IsEmpty())
			m_strWrongMessage="缺少操作符!";
		FreeTree(m_pRoot);
		m_pRoot = NULL;
	}
	
	if (m_pRoot == NULL)
		return m_nPos;
	else return -1;
}



//構造一個結點
CNode* CCalculate::AddSub()
{//加減
	CNode* nod;
	CNode* left = MultiplyDivide();
	CNode* right;
	if	(left == NULL)
	{
		if(m_strWrongMessage.IsEmpty())
			m_strWrongMessage="缺少操作數";
		return NULL; 
	}
	while ((m_strExpression[m_nPos]=='-') || (m_strExpression[m_nPos]=='+')) 
	{
		
		nod=new CNode;
		nod->left=left;
		nod->operate=m_strExpression[m_nPos];
		nod->prior=4;
		m_nPos++;
		right = MultiplyDivide();
		nod->right=right;
		if	(right == NULL)
		{
			if(m_strWrongMessage.IsEmpty())
				m_strWrongMessage="缺少'+'或'-'的操作數!";
			FreeTree(nod);
			return NULL; 
		}
		left = nod;
	}
	return left;
	
}

//調用了Putere()函數
CNode* CCalculate::MultiplyDivide()
{//乘除
	CNode* nod;
	CNode* left = Putere();
	CNode* right;
	if	(left == NULL) return NULL; 
	while ((m_strExpression[m_nPos]=='*') || (m_strExpression[m_nPos]=='/')) 
	{		
		nod=new CNode;
		nod->left=left;
		nod->operate=m_strExpression[m_nPos];
		nod->prior=3;
		m_nPos++;
		right = Putere();
		nod->right=right;
		if	(right == NULL) 
		{
			if(m_strWrongMessage.IsEmpty())
				m_strWrongMessage="缺少'×'或'÷'的操作數!";
			FreeTree(nod);
			return NULL; 
		}
		left = nod;		
	}
	return left;
}


//求冪的函數 返回的都是一個結點
CNode* CCalculate::Putere()
{//冪
	
	CNode* nod = NULL;
	CNode* arb1 = Factor();
	CNode* arb2;
	if	(arb1 == NULL) return NULL;  // In caz de eroare terminate
	while (m_strExpression[m_nPos]=='^') 
	{
		nod=new CNode;
		nod->left=arb1;
		nod->operate=m_strExpression[m_nPos];
		nod->prior=1;
		m_nPos++;
		arb2 = Factor();
		nod->right=arb2;
		if	(arb2 == NULL) 
		{
			if(m_strWrongMessage.IsEmpty())
				m_strWrongMessage="缺少'^'的操作數!";
			FreeTree(nod);
			return NULL;  // In caz de eroare terminate
		}
		arb1 = nod;
	}
	return arb1;
}


//m_strExpression為表達式的值 
CNode* CCalculate::Factor()
{//括號和絕對值、相反數
	CNode* nod = NULL,*nod2 = NULL,*left = NULL;	//表達式中有可能為''
	while(m_strExpression[m_nPos] == ' ' && m_strExpression[m_nPos] != '\0')
		m_nPos++;

	if (m_strExpression[m_nPos]=='-')//substration
	{
		nod = new CNode;		
		m_nPos++;
//		nod->right = AddSub();//something wrong;
//		nod->right = MultiplyDivide();///
		nod->right=Putere();
		if (nod->right == NULL)
		{
			if(m_strWrongMessage.IsEmpty())
				m_strWrongMessage="缺少'-'(負數)的操作數!";
			FreeTree(nod);
			return NULL;
		}
		else if(nod->right->operate!='@')
		{
			left = new CNode;
			left->left=NULL;
			left->operate='@';
			left->data=-1;
			nod->left=left;
			nod->operate='*';
			nod->prior=0;//將優先級設為0,是因為需要括號的運算。如:---3應變為(-1*(-1*(-3)))
		}
		else
		{

			nod->left=NULL;
			nod->data=-1*nod->right->data;
			delete nod->right;
			nod->right=NULL;
			nod->operate='#';
			nod->prior=0;

		}
		return nod;   
	}
	if (m_strExpression[m_nPos]=='(')//left bracket
	{
		m_nPos++;
		nod = AddSub();		
		if (nod == NULL) return NULL;
		if (m_strExpression[m_nPos]!=')')
		{
			if(m_strWrongMessage.IsEmpty())
				m_strWrongMessage="缺少右括號')'!";
			FreeTree(nod);
			return NULL;
		}
		nod->prior=0;
		m_nPos++;
		return nod;
	}
	else if (m_strExpression[m_nPos]=='|')//abs
	{
		m_nPos++;
		nod2 = AddSub();
		if (nod2 == NULL) return NULL;
		if (m_strExpression[m_nPos]!='|')
		{
			if(m_strWrongMessage.IsEmpty())
				m_strWrongMessage="缺少絕對值操作符'|'!";
			FreeTree(nod);
			return NULL;
		}
		nod = new CNode;
		nod->left=nod2;
		nod->right=NULL;
		nod->operate='|';
		nod->prior=0;
		m_nPos++;
		return nod;
	}
	else return Operand();
	return nod;
}

//operator 
CNode* CCalculate::Operand()
{//操作數
	int nStartPos;//開始位置
	CNode* nod = NULL;
	CNode* result = NULL;
	nStartPos = m_nPos;
	if (m_strExpression[m_nPos]=='\0') result = NULL;
	if (isdigit(m_strExpression[m_nPos]))	// 數字
	{
		while  (isdigit(m_strExpression[m_nPos]) || (m_strExpression[m_nPos]=='.'))	
			m_nPos++;
		nod = new CNode;
		nod->left = NULL; 
		nod->right = NULL;
		nod->operate = '@';
		nod->data = atof(m_strExpression.Mid(nStartPos,m_nPos-nStartPos));//convert the CString to data
		result = nod;
	}
	return result;
}


double CCalculate::Calculate(CNode* node)
{	
	if (node==NULL) 
	{
//		AfxMessageBox(m_strWrongMessage);
		return -1;
	}
	double oper1=0.0,oper2=0.0;
	if(node->left==NULL&&node->right==NULL)
		return node->data;
	else
	{
		oper1=Calculate(node->left);//取左邊的數
		oper2=Calculate(node->right);//取右邊的數
		
		//calculation
		double result=GetValue(node->operate,oper1,oper2);
//		MakeStep(oper1,oper2,node->operate,result);
		return result;
		
	}
}


//calculation
double CCalculate::GetValue(char operate,double oper1,double oper2)
{
	switch(operate)
	{
		case '*': return oper1*oper2;
		case '/'://特殊的情況
			{
				if (oper2==0) 
				{
//					cout<<"Warning:Denominator cann't be zero"<<endl;
					if(m_strWrongMessage.IsEmpty())
						m_strWrongMessage="除數不能為零!";
//					AfxMessageBox("除數不能為零!",MB_ICONSTOP|MB_OK);
					return 0;
				}
				return oper1/oper2;
			}
		case '+': return oper1+oper2;
		case '-': return oper1-oper2;
		case '|': return fabs(oper1);
		case '^': return pow(oper1,oper2);

	}
	return 0;
}


void CCalculate::Serialize(CArchive& ar)
{
	CObject::Serialize(ar);
	if (ar.IsStoring())
	{
/*		ar << m_m_nPosition;
		ar << (WORD)m_bPen;
		ar.Write(&m_logpen, sizeof(LOGPEN));
		ar << (WORD)m_bBrush;
		ar.Write(&m_logbrush, sizeof(LOGBRUSH));*/
	}
	else
	{
		// get the document back pointer from the archive
/*		m_pDocument = (CMathDoc*)ar.m_pDocument;
		ASSERT_VALID(m_pDocument);
		ASSERT_KINDOF(CMathDoc, m_pDocument);

		WORD wTemp;
		ar >> m_m_nPosition;
		ar >> wTemp; m_bPen = (BOOL)wTemp;
		ar.Read(&m_logpen,sizeof(LOGPEN));
		ar >> wTemp; m_bBrush = (BOOL)wTemp;
		ar.Read(&m_logbrush, sizeof(LOGBRUSH));*/
	}
}


BOOL CCalculate::IsValid(CString* pMessage, int* pPos)
{
	if(MakeTree()!=-1)
	{
		if(pPos!=NULL)
			*pPos=m_nPos;
		if(pMessage!=NULL)
			*pMessage=m_strWrongMessage;
		m_bIsValid=FALSE;
		return FALSE;
	}
	if(pPos!=NULL)
		*pPos=-1;
	if(pMessage!=NULL)
		*pMessage="";
	m_bIsValid=TRUE;
	return TRUE;
}

double CCalculate::GetResult()
{
	if(!m_bIsValid) return 0;
	
	return Calculate(m_pRoot);
}

void CCalculate::ResetExp(const CString &strExp)
{
	m_strExpression=strExp+'\0'+'\0';
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区福利| 亚洲国产精品影院| 884aa四虎影成人精品一区| 国产精品中文字幕欧美| 日本午夜精品视频在线观看 | 国产午夜精品一区二区三区视频 | 91精品国产全国免费观看| 成人黄动漫网站免费app| 蜜桃一区二区三区在线| 夜夜嗨av一区二区三区| 亚洲欧美日韩国产一区二区三区 | 日韩美女视频一区二区在线观看| 91免费国产在线| 岛国av在线一区| 国产乱人伦精品一区二区在线观看| 午夜av电影一区| 亚洲图片欧美色图| 五月综合激情网| 日韩国产精品久久| 日韩高清在线观看| 免费看欧美女人艹b| 日韩精品福利网| 久久精品久久综合| 精品一区二区在线看| 国产资源在线一区| 国产一区二区三区观看| 日本不卡的三区四区五区| 蜜臀av一级做a爰片久久| 亚洲视频一区二区在线观看| 国产精品毛片大码女人| 国产精品每日更新| 久久精品亚洲乱码伦伦中文| 国产亚洲一区二区三区四区| 欧美xxx久久| 精品国产乱码久久久久久久| 欧美男人的天堂一二区| 欧美肥妇free| 久久天堂av综合合色蜜桃网| 国产午夜亚洲精品理论片色戒| 国产精品无圣光一区二区| 综合色天天鬼久久鬼色| 亚洲图片一区二区| 国产一区二区福利| 91啪亚洲精品| 日韩欧美国产一区二区在线播放| 精品国产一区二区三区久久影院| 日本一区二区综合亚洲| 亚洲男同1069视频| 麻豆国产欧美日韩综合精品二区| 国产综合色产在线精品| 91亚洲午夜精品久久久久久| 99精品视频一区二区| 欧美日韩精品一区二区三区| 欧美一区二区三区喷汁尤物| 精品国产sm最大网站免费看| 国产精品视频免费| 亚洲国产精品嫩草影院| 精品一二线国产| 成人黄色av网站在线| 欧美日韩一区国产| 国产三级一区二区三区| 亚洲大片一区二区三区| 狠狠色丁香久久婷婷综合_中| 91视频免费观看| 欧美一级片在线看| 亚洲精品日韩综合观看成人91| 青草av.久久免费一区| 99re热这里只有精品免费视频| 制服.丝袜.亚洲.另类.中文| 中文av一区特黄| 亚洲精品高清在线| 秋霞午夜鲁丝一区二区老狼| 国产精品一区二区三区乱码| 欧美亚洲一区二区在线观看| 国产三区在线成人av| 日韩福利视频网| aaa亚洲精品| 26uuu亚洲| 亚洲成a人在线观看| 99在线热播精品免费| 久久精品人人做人人综合| 国产在线精品一区二区夜色| 色婷婷亚洲综合| 国产精品毛片无遮挡高清| 国产一区二区三区在线观看免费| 欧美日韩精品免费观看视频| 亚洲一级二级在线| 色哦色哦哦色天天综合| 中文字幕一区二区三| 国产很黄免费观看久久| 国产视频911| 国产精品中文字幕欧美| 久久久久国色av免费看影院| 久草这里只有精品视频| 日韩久久免费av| 精品写真视频在线观看| 欧美一区二区精美| 老司机免费视频一区二区| 91精品国产aⅴ一区二区| 亚洲成人在线网站| 欧美日本免费一区二区三区| 午夜日韩在线观看| 在线不卡一区二区| 日韩中文字幕av电影| 欧美精品v国产精品v日韩精品 | 精品粉嫩超白一线天av| 久久超碰97中文字幕| 精品奇米国产一区二区三区| 美女视频黄频大全不卡视频在线播放| 91麻豆精品国产91久久久久| 精品一区二区三区久久| 国产欧美日本一区视频| 91亚洲男人天堂| 午夜久久久影院| 精品三级av在线| 国产精品一区久久久久| 中文字幕国产一区| 一本色道亚洲精品aⅴ| 亚洲一区在线播放| 91精品国产综合久久香蕉的特点| 日韩成人一级大片| 国产精品久久免费看| 欧美性生活久久| 久久99精品久久久久| 国产精品久线在线观看| 欧美日韩激情在线| 精品在线观看免费| 日韩美女视频一区二区| 欧美精品久久99久久在免费线| 九色|91porny| 一区二区在线免费| 日韩午夜在线观看| 成人av电影观看| 五月婷婷综合在线| 国产精品美女www爽爽爽| 欧美日韩午夜在线视频| 大桥未久av一区二区三区中文| 亚洲一区视频在线| 精品国产免费久久| 91久久精品国产91性色tv| 激情综合色丁香一区二区| 亚洲狼人国产精品| 国产精品三级电影| 日韩欧美亚洲国产另类| 欧美怡红院视频| 国产不卡视频在线观看| 日韩电影在线观看一区| 亚洲一区二区视频| 中文字幕在线观看一区| 久久久国产精品午夜一区ai换脸| 欧美日韩国产高清一区二区| 成人免费高清在线| 国产电影一区二区三区| 免费xxxx性欧美18vr| 亚洲欧美在线高清| 中文字幕av一区二区三区| 欧美一二三区在线| 欧美精品自拍偷拍动漫精品| 色88888久久久久久影院按摩| 成人一区二区三区在线观看| 精品一区二区在线观看| 蜜桃一区二区三区在线观看| 午夜影院久久久| 亚洲午夜久久久久| 亚洲一区二区三区美女| 悠悠色在线精品| 亚洲精品成人a在线观看| 亚洲欧洲日韩av| 日韩理论片网站| 欧美激情资源网| 久久久国际精品| 日本一区二区三区电影| 亚洲欧洲一区二区在线播放| 欧美高清一级片在线观看| 国产日韩精品视频一区| 国产亚洲精品超碰| 国产丝袜欧美中文另类| 国产清纯白嫩初高生在线观看91| 国产亚洲人成网站| 中文字幕免费在线观看视频一区| 国产日韩av一区二区| 中文字幕中文在线不卡住| 日韩毛片视频在线看| 一区二区三区精密机械公司| 香蕉成人啪国产精品视频综合网 | 亚洲精品视频在线看| 亚洲综合在线电影| 亚洲成人激情综合网| 五月婷婷激情综合| 久久99精品一区二区三区三区| 国产一区二区免费看| 不卡的电影网站| 在线观看欧美精品| 欧美年轻男男videosbes| 欧美xxxxxxxx| 国产精品成人网| 天天综合色天天综合| 国产又黄又大久久| 91免费国产视频网站| 91精品国产高清一区二区三区|