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

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

?? stringresolution.cpp

?? 最優化算法
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// StringResolution.cpp: implementation of the CStringResolution class.
/***********************************************************************************************
*	Copyright (c) Zhou Yuncai(周云才 江漢石油學院計算機系),2002
*	All rights reserved EXCEPT as allow by the following statements:
*	You can freely use this file for your own work (personal or commercial).
*	But,you cannot remove this copyright and notice. 
*	You cannot distribute modified versions of the source code in this package. 
*	You cannot use this file in printed media without the express permission of the author.
*	Zhou Yuncai makes no representation about the suitability of this software for any purpose.
*	It is provided "as is" without express or implied warranty of any kind, including any implied
*	warranty of merchantability, fitness for a particular purpose, or non-infringement.
*	The entire risk as to the quality and performance of the software is with you. 
*	Zhou Yuncai shall not be liable for any damages suffered by you or any third party as a result of
*	using or distributing this software. 
*	In no event will Zhou Yuncai be liable for any lost revenue, profit, or data, or for direct,
*	indirect, special, consequential, incidental, or punitive damages, however caused and regardless of
*	the theory of liability, arising out of the use of or inability to use software, even if Zhou Yuncai
*	has been advised of the possibility of such damages. 
*	Should the software prove defective, you assume the cost of all necessary servicing, repair, 
*	or correction. If you think you've found an error, please e-mail the correction using the 
*	form you will find to zyc262@163.net
*	address:湖北省荊州市江漢石油學院計算機系
**********************************************************************************************/

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

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

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////
#ifdef _ERROR_INFO_H_
BEGIN_CATCH_MATH_ERROR
_BEGIN_GET_TYPE
GET_ERROR_TYPE(_DOMAIN,BIGNUMBER,Argument domain error.)
GET_ERROR_TYPE(_SING,BIGNUMBER,Argument singularity.)
GET_ERROR_TYPE(_OVERFLOW,BIGNUMBER,Overflow range error.)
GET_ERROR_TYPE(_UNDERFLOW,0,Underflow range error.)
GET_ERROR_TYPE(_TLOSS,0,Total loss of precision.)
GET_ERROR_TYPE(_PLOSS,0,Partial loss of precision.)
_END_GET_TYPE
GET_ERROR_FUNCTION(pow,power function exception. )
GET_ERROR_FUNCTION(tan,tangent function exception. )
GET_ERROR_FUNCTION(asin,arcsine function exception. )
GET_ERROR_FUNCTION(acos,arccosine function exception. )
END_CATCH_MATH_ERROR

IMPLEMENT_CATCH_ERROR(CStringResolution)
#endif

CStringResolution::CStringResolution(char*formula)
:m_oprandNum(0),m_oprandANum(0),m_operatorNum(0)
{
	m_operator=0;
	m_oprand=0;
	m_oprandA=0;
#ifdef _ERROR_INFO_H_
	_SAVE_ERROR_INFO(0,FALSE,"Good");
#endif
	if(formula)
	{
		m_formula=formula;
		Initialize();
	}
}

CStringResolution::~CStringResolution()
{
	if(m_operator)
		delete[]m_operator;
	if(m_oprand)
		delete[]m_oprand;
	if(m_oprandA)
		delete[]m_oprandA;
}

void CStringResolution::SetFormula(char *formula)
{
	if(!formula)
		return;
	m_formula=formula;
	if(m_operator)
	{
		delete[]m_operator;
		m_operator=0;
	}
	if(m_oprand)
	{
		delete[]m_oprand;
		m_oprand=0;
	}
	if(m_oprandA)
	{
		delete[]m_oprandA;
		m_oprandA=0;
	}
	m_oprandNum=0,m_oprandANum=0,m_operatorNum=0;
#ifdef _ERROR_INFO_H_
	_SAVE_ERROR_INFO(0,FALSE,"Good!");
#endif
	Initialize();
}
int CStringResolution::IsFormula()
{
	int bRet=0;
	stack<char> charStack;
	int i,num=m_formula.GetLength();
	char notChar[]={';','\'',':',' ','[',']','{','}','\\','|',',','\"','=','&','%','$','@','#','!','`','~','?'};
	int notNum=sizeof notChar;
	for(i=0;i<num;i++)
	{
		for(int j=0;j<notNum;j++)
		{
			if(m_formula[i]==notChar[j])
			{
				CString s;
				s.Format("The %dth character,\"%c\" is invalidated!",i+1,m_formula[i]);
#ifdef _ERROR_INFO_H_
				_SAVE_ERROR_INFO(-i-1,TRUE,s);
#endif
				return -i-1;//the ith symbol is invalidating.
			}
		}
	}
	for(i=0;i<num;i++)
	{
		if(m_formula[i]=='(')
			charStack.push('(');
		if(m_formula[i]==')')
		{
			if(charStack.empty())
			{
#ifdef _ERROR_INFO_H_
				_SAVE_ERROR_INFO(1,TRUE,"There are some more right brackets!");
#endif
				return 1;//right bracket if more.
			}
			else
				charStack.pop();
		}
	}
	if(!charStack.empty())
	{
#ifdef _ERROR_INFO_H_
		_SAVE_ERROR_INFO(2,TRUE,"There are some more left brackets!");
#endif
		return 2;//left bracket is more.
	}
	return bRet;
}

BOOL CStringResolution::GetStack(OperatorStack &Operator, OperandStack &Oprand)
{
	if(IsFormula())
		return FALSE;//illogicality return
	BOOL bRet=TRUE;
	EmptyStack(Operator);
	EmptyStack(Oprand);
	CString string=m_formula;
	bRet=bRet&&GetOperatorStack(Operator,string);
	bRet=bRet&&GetOperandStack(Oprand,string);
	return bRet;
}
BOOL CStringResolution::Initialize()
{
	BOOL bRet=FALSE;
	OperatorStack Op; OperandStack Od;
	bRet=GetStack(Op,Od);
	if(!bRet)
	{
		EmptyStack(Op);
		EmptyStack(Od);
		return FALSE;
	}
	m_oprandNum=Od.size(),m_operatorNum=Op.size();
	if(m_operatorNum)
		m_operator=new COperator[m_operatorNum];
	if(m_oprandNum)
		m_oprand=new COperand[m_oprandNum];
	int i;
	for(i=0;i<m_operatorNum;i++)
	{
		COperator*op=Op.top();
		m_operator[m_operatorNum-i-1]=*op;
		Op.pop();
		delete op;
	}
	for(i=0;i<m_oprandNum;i++)
	{
		COperand*od=Od.top();
		m_oprand[m_oprandNum-i-1]=*od;
		Od.pop();
		delete od;
	}
	m_oprandA=new COperand[m_oprandNum];
	BOOL IsIn=FALSE;
	for(i=0;i<m_oprandNum;i++)
	{
		for(int j=0;j<m_oprandANum;j++)
		{
			if(m_oprand[i]==m_oprandA[j])
			{
				IsIn=TRUE;
				break;
			}
		}
		if(!IsIn&&!m_oprand[i].m_IsConst)
		{
			m_oprandA[m_oprandANum]=m_oprand[i];
			m_oprandANum++;
		}
		IsIn=FALSE;
	}
	return TRUE;
}

double CStringResolution::Computer(OperatorStack &Operator, OperandStack &Oprand)
{
	double value =0.0;
	if(Operator.empty())
	{
		if(Oprand.size()==1)
		{	
			COperand* od=Oprand.top();
			value=atof(od->m_name);
			delete od;
			return value;
		}
		else
		{
			while(!Oprand.empty())
			{
				COperand*od=Oprand.top();
				Oprand.pop();
				delete od;
			}
#ifdef _ERROR_INFO_H_
			_SAVE_ERROR_INFO(12,TRUE,"Oprand is less or more!");
#endif
			return BIGNUMBER;
		}
	}
	OperatorStack tmpOO;
	OperandStack tmpOD;
	COperator* op=0,*op1=0;
	COperand *oprand=0,*oprand1=0;
	op=Operator.top();
	Operator.pop();
	if(!Operator.empty())
		op1=Operator.top();
	while(op1&&(op1->m_level>op->m_level))
	{
		tmpOO.push(op);
		if(op->m_type==BINARY)
		{
			if(!Oprand.empty())
			{
				oprand=Oprand.top();
				Oprand.pop();
				tmpOD.push(oprand);
			}
		}
		op=op1;
		Operator.pop();
		if(!Operator.empty())
			op1=Operator.top();
		else
			op1=0;
	}
	if(op->m_type==UNARY)
	{
		if(Oprand.empty())
		{
#ifdef _ERROR_INFO_H_
			_SAVE_ERROR_INFO(12,TRUE,"Oprand is less!");
#endif
			return BIGNUMBER;
		}
		oprand=Oprand.top();
		double x=computing(op,oprand);
		oprand->m_name.Format("%g",x);
	}
	else
	{
		if(Oprand.empty())
		{
#ifdef _ERROR_INFO_H_
			_SAVE_ERROR_INFO(12,TRUE,"Oprand less!");
#endif
			return BIGNUMBER;
		}
		oprand1=Oprand.top();
		Oprand.pop();
		if(Oprand.empty())
		{
#ifdef _ERROR_INFO_H_
			_SAVE_ERROR_INFO(12,TRUE,"Oprand less!");
#endif
			return BIGNUMBER;
		}
		oprand=Oprand.top();
		double x=computing(op,oprand1,oprand);
		oprand->m_name.Format("%g",x);
		delete oprand1;
	}
	delete op;
	while(!tmpOO.empty())
	{
		op=tmpOO.top();
		tmpOO.pop();
		Operator.push(op);
	}
	while(!tmpOD.empty())
	{
		oprand=tmpOD.top();
		tmpOD.pop();
		Oprand.push(oprand);
	}
	return Computer(Operator,Oprand);
}

double CStringResolution::computer(double variantValue[], int num)
{
#ifdef _ERROR_INFO_H_
	PROCESSION_ERROR
#endif
	double value=0.0;
	int i;
	if(num<m_oprandANum)
	{
#ifdef _ERROR_INFO_H_
		_SAVE_ERROR_INFO(10,FALSE,"There are less digital number than variants");
#endif
		return BIGNUMBER;
	}
	OperatorStack Operator;
	OperandStack Oprand;
	for(i=0;i<m_operatorNum;i++)
	{
		COperator*op=new COperator;
		*op=m_operator[m_operatorNum-i-1];
		Operator.push(op);
	}
	for(i=0;i<m_oprandNum;i++)
	{
		COperand*od=new COperand;
		*od=m_oprand[m_oprandNum-i-1];
		for(int j=0;j<m_oprandANum;j++)
		{
			if(*od==m_oprandA[j])
				od->m_name.Format("%g",variantValue[j]);
		}
		Oprand.push(od);
	}
	value=Computer(Operator,Oprand);
	return value;
}

CString CStringResolution::GetErrorInformation()
{
	CString value;
#ifndef _ERROR_INFO_H_
	value="There is no error information.";
#else
	GET_ERROR_INFORMATION(value)
#endif
	return value;
}

BOOL CStringResolution::EmptyStack(OperatorStack Op)
{
	while(!Op.empty())
	{
		COperator*op=Op.top();
		Op.pop();
		delete op;
	}
	return TRUE;
}
BOOL CStringResolution::EmptyStack(OperandStack Od)
{
	while(!Od.empty())
	{
		COperand*od=Od.top();
		Od.pop();
		delete od;
	}
	return TRUE;
}

BOOL CStringResolution::GetOperatorStack(OperatorStack &Operator, CString &string)
{
	BOOL bRet=TRUE;
	int num=string.GetLength();
	int i=0;
	int level=0;
	while(i<num)
	{
		if(string[i]=='(')
		{
			level+=LEVELS;
			string.SetAt(i,'#');
			i++;
		}
		else if(string[i]==')')
		{
			level-=LEVELS;
			string.SetAt(i,'@');
			i++;
		}
		else if(string[i]=='+'||string[i]=='-')
		{

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国内精品在线播放| 亚洲一线二线三线久久久| 欧美高清性hdvideosex| 正在播放亚洲一区| 91欧美一区二区| 美国三级日本三级久久99| 日韩精品每日更新| 日日摸夜夜添夜夜添精品视频| 一级女性全黄久久生活片免费| 一区二区三区视频在线看| 一区二区三区免费观看| 亚洲一区二区三区影院| 亚洲一区在线观看视频| 亚洲国产精品久久一线不卡| 亚洲综合男人的天堂| 亚洲成在人线在线播放| 日产精品久久久久久久性色 | 亚洲视频香蕉人妖| 中文在线免费一区三区高中清不卡| 国产欧美1区2区3区| 国产精品区一区二区三| 亚洲欧洲av色图| 亚洲已满18点击进入久久| 日韩国产精品久久久| 久久99精品国产91久久来源| 成人免费av资源| 一本一道综合狠狠老| 欧美日韩中文另类| 日韩精品中文字幕一区二区三区| 久久日一线二线三线suv| 中文欧美字幕免费| 欧美一区二区三区不卡| 亚洲精品国产视频| 欧美一区二区视频在线观看| 丝袜美腿亚洲一区| 99久久国产综合精品色伊| 精品福利在线导航| 国产伦理精品不卡| 不卡影院免费观看| 欧美丝袜丝交足nylons| 日韩久久精品一区| **性色生活片久久毛片| 午夜久久久影院| 国产东北露脸精品视频| 在线看日本不卡| 日本在线不卡一区| 亚洲国产wwwccc36天堂| 国产一区二区在线视频| 91福利资源站| 2021久久国产精品不只是精品| 综合激情网...| 美女视频一区二区| 一本久久a久久精品亚洲| 日韩一级成人av| **欧美大码日韩| 国产一区二区在线观看视频| 日本福利一区二区| 久久久噜噜噜久久中文字幕色伊伊| 亚洲色图一区二区| 狠狠色丁香久久婷婷综| 在线免费观看视频一区| 国产欧美视频一区二区三区| 欧美电影免费观看高清完整版在| 自拍偷拍亚洲欧美日韩| 久久99精品国产麻豆不卡| 欧美亚洲另类激情小说| 久久精品欧美一区二区三区不卡| 五月婷婷综合网| 91免费在线播放| 久久久www成人免费无遮挡大片| 成人高清免费观看| 久久九九久精品国产免费直播| 日韩一区二区三区四区| 亚洲精品日日夜夜| 国产成人综合视频| 精品久久久久一区| 午夜a成v人精品| 色综合激情五月| 欧美国产精品专区| 久久99国内精品| 911精品国产一区二区在线| 亚洲柠檬福利资源导航| 风流少妇一区二区| 精品国产电影一区二区| 日韩精品五月天| 欧美在线啊v一区| 欧美日韩在线免费视频| 国产精品短视频| 国产不卡一区视频| 精品国产一区二区三区忘忧草 | 日韩国产一二三区| 色嗨嗨av一区二区三区| 中文字幕在线观看一区二区| 国产一区二区精品久久99| 夜夜夜精品看看| 久久成人综合网| 91精品国产综合久久福利软件| 亚洲国产综合91精品麻豆| 91麻豆国产在线观看| 亚洲欧洲在线观看av| 粉嫩在线一区二区三区视频| 久久久久久久性| 国产精品白丝jk白祙喷水网站| 欧美电影免费观看高清完整版| 久久国产成人午夜av影院| 日韩欧美国产一二三区| 免费成人av资源网| 精品三级av在线| 捆绑调教美女网站视频一区| 欧美大片国产精品| 国产一区日韩二区欧美三区| wwwwww.欧美系列| 日本一区二区三级电影在线观看| 国产一区二区三区久久悠悠色av| 欧美精品一区二区三区久久久| 久久99这里只有精品| 精品国产99国产精品| 国产真实乱子伦精品视频| 久久久不卡网国产精品二区| 国产大陆亚洲精品国产| 国产精品白丝在线| 日韩精品在线网站| 久久99热狠狠色一区二区| 久久美女艺术照精彩视频福利播放 | 久久网站热最新地址| 国产成人精品免费看| 亚洲欧洲日本在线| 欧美性色黄大片| 日本不卡一二三| 久久精品人人做人人爽人人| 波多野结衣精品在线| 一区二区三区成人在线视频| 在线播放欧美女士性生活| 久久国产精品99精品国产| 国产清纯白嫩初高生在线观看91| av不卡在线播放| 欧美mv日韩mv| 成人在线一区二区三区| 亚洲精品视频在线观看免费| 欧美伦理影视网| 国内精品久久久久影院薰衣草| 国产精品久久久久久久久动漫| 在线中文字幕不卡| 久久激情综合网| 亚洲欧洲韩国日本视频| 亚洲特黄一级片| 99视频精品全部免费在线| 亚洲aⅴ怡春院| 精品国产免费一区二区三区四区| 不卡的电影网站| 午夜一区二区三区视频| 久久久久久久久久久电影| 欧美日韩成人综合| 蜜臀av一级做a爰片久久| 国产精品你懂的在线欣赏| 欧美色男人天堂| 粉嫩高潮美女一区二区三区| 亚洲第一会所有码转帖| 国产亚洲一区二区三区在线观看| 欧美亚洲国产一卡| 国产成人在线免费| 午夜免费久久看| 中文字幕在线观看不卡视频| 欧美一区二区三区色| a在线欧美一区| 国产精品美女久久久久久久| 欧美人动与zoxxxx乱| 成人性生交大合| 视频在线观看一区二区三区| 国产精品国产自产拍高清av王其| 日韩片之四级片| 日本韩国欧美一区| 国产成人av电影在线| 久久精品国产99久久6| 亚洲午夜视频在线观看| 久久精品人人做人人爽人人| 成人欧美一区二区三区白人| 欧美一区二区在线免费播放| 色综合久久中文字幕综合网| 国产成人免费9x9x人网站视频| 天堂蜜桃91精品| 亚洲精品精品亚洲| 国产精品网站在线观看| 精品日韩一区二区| 91麻豆精品国产91久久久| 91久久精品一区二区三| 成人黄色国产精品网站大全在线免费观看 | 精品国产乱码久久久久久老虎 | 亚洲欧洲日韩综合一区二区| 丰满少妇久久久久久久| 精品夜夜嗨av一区二区三区| 日韩精品一区第一页| 激情文学综合插| 国产精品私人影院| 久久久综合激的五月天| 日韩精品在线网站| 69堂亚洲精品首页| 欧美精品高清视频| 欧美日韩另类一区| 欧美三级日韩在线|