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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? express.cpp

?? 任意數(shù)學(xué)表達(dá)式計算的源碼及測試軟件
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
			d2=atof(s2);
			d3=d1/d2;
			s1.Format("%f",d3);
			str=ReplaceBetweenPos(str,s1,start,end);
	    	GetSingleValue(str,result);

		}


	}
	else
	if (IsTimesExist(str))
	{

		pos=GetJJCCPos(str,"*");
		GetJJCCTwoParm(str,pos,&s1,&s2,&start,&end);
		d1=atof(s1);
		d2=atof(s2);
		d3=d1*d2;
		s1.Format("%f",d3);
		str=ReplaceBetweenPos(str,s1,start,end);
		GetSingleValue(str,result);

	}
	else
		if (IsDivideExist(str))
	{

				
	
			pos=GetJJCCPos(str,"/");
			GetJJCCTwoParm(str,pos,&s1,&s2,&start,&end);
			d1=atof(s1);
			d2=atof(s2);
			d3=d1/d2;
			s1.Format("%f",d3);
			str=ReplaceBetweenPos(str,s1,start,end);
	    	GetSingleValue(str,result);

	}
	else
		if (IsAddExist(str)&&IsPulsExist(str))
		{
			int pos1=GetJJCCPos(str,"*");
			pos=GetJJCCPos(str,"/");
	    	if (pos>pos1)
			{
				pos=GetJJCCPos(str,"+");
				GetJJCCTwoParm(str,pos,&s1,&s2,&start,&end);
				d1=atof(s1);
				d2=atof(s2);
				d3=d1+d2;
				s1.Format("%f",d3);
				str=ReplaceBetweenPos(str,s1,start,end);
	        	GetSingleValue(str,result);

			}
			else
			{
				pos=GetJJCCPos(str,"-");
				GetJJCCTwoParm(str,pos,&s1,&s2,&start,&end);
				d1=atof(s1);
				d2=atof(s2);
				d3=d1-d2;
				s1.Format("%f",d3);
				str=ReplaceBetweenPos(str,s1,start,end);
				GetSingleValue(str,result);

			}
		}
		else
		if (IsAddExist(str))
		{
			pos=GetJJCCPos(str,"+");
			GetJJCCTwoParm(str,pos,&s1,&s2,&start,&end);
			d1=atof(s1);
			d2=atof(s2);
			d3=d1+d2;
			s1.Format("%f",d3);
			str=ReplaceBetweenPos(str,s1,start,end);
	    	GetSingleValue(str,result);

		}
		else
			if (IsPulsExist(str))
			{
				pos=GetJJCCPos(str,"-");
				GetJJCCTwoParm(str,pos,&s1,&s2,&start,&end);
				d1=atof(s1);
				d2=atof(s2);
				d3=d1-d2;
				s1.Format("%f",d3);
				str=ReplaceBetweenPos(str,s1,start,end);
				GetSingleValue(str,result);

			}
			else
			{
			    d1=atof(str);
				result=d1;
            	return ;
			}


}
int CExpress::GetJJCCNum(CString str,CString name)
{
	int n=0;
	int falg=0;
	while(str.Find(name)!=-1)
	{
		n=str.Find(name);
		str.SetAt(n,'@');
		falg++;	
	}
	return falg;

}
void CExpress::GetSignFuncVal(CString str,double &result)
{
	int s_s,s_e,p_s,p_e,style;
	CString p1,p2;
	double result1,result2;
	if (IsContainSign(str))
	{
		style=GetSignStyle(str,&s_s,&s_e,&p_s,&p_e);
		if (style==SIN)
		{	
		
			p1=GetParmString(str,p_s,p_e);
			GetSingleValue(p1,result1);
			p2.Format("%f",sin(result1*PI/180.0));
			str=ReplaceBetweenPos(str,p2,s_s,p_e);


		
		}
		if (style==COS)
		{
			
			p1=GetParmString(str,p_s,p_e);
			GetSingleValue(p1,result1);
			p2.Format("%f",cos(result1*PI/180.0));
			str=ReplaceBetweenPos(str,p2,s_s,p_e);

	
		}
		if (style==TAN)
		{
	
			p1=GetParmString(str,p_s,p_e);
			GetSingleValue(p1,result1);
			p2.Format("%f",tan(result1*PI/180.0));
			str=ReplaceBetweenPos(str,p2,s_s,p_e);

		}
		if (style==EXP)
		{
		
			p1=GetParmString(str,p_s,p_e);
			GetSingleValue(p1,result1);
			p2.Format("%f",exp(result1));
			str=ReplaceBetweenPos(str,p2,s_s,p_e);

		}
		if (style==LOG)
		{
	
			GetParmTwo(str,p_s,p_e,&p1,&p2);
			GetSingleValue(p1,result1);
			GetSingleValue(p2,result2);
			p2.Format("%f",log(result2)/log(result1));
			str=ReplaceBetweenPos(str,p2,s_s,p_e);
		}
		if (style==ASIN)
		{
		//	AfxMessageBox("asin");
			p1=GetParmString(str,p_s,p_e);
			GetSingleValue(p1,result1);
			p2.Format("%f",asin(result1)*180.0/PI);
			str=ReplaceBetweenPos(str,p2,s_s,p_e);

		}
		if (style==ACOS)
		{
		//	AfxMessageBox("acos");
			p1=GetParmString(str,p_s,p_e);
			GetSingleValue(p1,result1);
			p2.Format("%f",acos(result1)*180.0/PI);
			str=ReplaceBetweenPos(str,p2,s_s,p_e);

		}
		if (style==ATAN)
		{
		//	AfxMessageBox("atan");
			p1=GetParmString(str,p_s,p_e);
			GetSingleValue(p1,result1);
			p2.Format("%f",atan(result1)*180.0/PI);
			str=ReplaceBetweenPos(str,p2,s_s,p_e);

		}
		if (style==SIGN)
		{
	
			p1=GetParmString(str,p_s,p_e);
			GetSingleValue(p1,result1);
			int i=0;
			if (result1<0)
			{
				i=-1;
			}
			else
			if (result1>0)
			{
				i=1;
			}
			else
				if (abs(result1)<0.000000001)
				{
					i=0;
				}
			p2.Format("%d",i);
			str=ReplaceBetweenPos(str,p2,s_s,p_e);
		
		}
		if (style==POW)
		{
		//	AfxMessageBox("pow");
			GetParmTwo(str,p_s,p_e,&p1,&p2);
			GetSingleValue(p1,result1);
			GetSingleValue(p2,result2);
			p2.Format("%f",pow(result1,result2));
			str=ReplaceBetweenPos(str,p2,s_s,p_e);		
		}
       
		if (IsContainSign(str))
	    	GetSignFuncVal(str,result);
		else
		{
//			AfxMessageBox("GetSingleValue");
			GetSingleValue(str,result);
		}

	}
	else
	{
		
		GetSingleValue(str,result);
	}

	
}
bool CExpress::IsContainBracket(CString str)
{
	if(str.Find("(",0)==-1) return false;
	else return true;
	}

void CExpress::GetBracketResult(CString str,double &result)
{
	int start,end;
	CString s1,s2;
	double r;
	fprintf(resultF,"step%d=%s\n",stepNum+1,str);
	step[stepNum++]=str+"/n";
	if(IsContainBracket(str))
	{

		GetBracketPos(str,&start,&end);
		s1=GetStrFromStartAndEnd(str,start,end);
		GetSignFuncVal(s1,r);
		s2.Format("%f",r);
		str=ReplaceBetweenPos(str,s2,start,end);
		if (IsContainBracket(str))
		{
			fprintf(resultF,"step%d=%s\n",stepNum+1,str);
			step[stepNum++]=str+"/n";
			GetBracketResult(str,result);
		}
		else
		{
			step[stepNum++]=str+"/n";
			GetSignFuncVal(str,result);
    		fprintf(resultF,"result=%.4f\n",result);
		}
	
	}
	else
	{
	
		step[stepNum++]=str+"/n";
		GetSignFuncVal(str,result);
		fprintf(resultF,"result=%.4f\n",result);
	}
}
double CExpress::GetResultFrString(CString str)
{
	if (!Cheak(str))
	{
		AfxMessageBox("表達(dá)式非法!");
		return 0;
	}
	
	resultF=fopen("result.txt","w");
	fprintf(resultF,"****************計算步驟*******************\n");
	stepNum=0;
	double result;
	GetBracketResult(str,result);
	fclose(resultF);
	return result;
}
double CExpress::GetResultFrString1(CString str,CString parm,double val)
{
	//if (!Cheak(str))
	{
	//	AfxMessageBox("表達(dá)式非法!");
	//	return 0;
	}
	CString st;
	st.Format("%f",val);
	str.Replace(parm,st);
	return GetResultFrString(str);
}


double CExpress::GetResultFrString2(CString str,CString parm1,double val1,CString parm2,double val2)
{
	if (!Cheak(str))
	{
		AfxMessageBox("表達(dá)式非法!");
		return 0;
	}
	CString st1;
	st1.Format("%f",val1);
	str.Replace(parm1,st1);
	st1.Format("%f",val2);
	str.Replace(parm2,st1);
	return GetResultFrString(str);
}double CExpress::GetResultFrStringN(CString str,CString parm[],double val[],int N)
{
	if (!Cheak(str))
	{
		AfxMessageBox("表達(dá)式非法!");
		return 0;
	}
	CString st;
	for (int i=0;i<N;i++)
	{
    	st.Format("%f",val[i]);
    	str.Replace(parm[i],st);
	}
	return GetResultFrString(str);
}
BOOL CExpress::Cheak(CString &str)
{
	CString s=str; 
	int i,j;
	int pos;
	i=0;j=0;
	//////////////////////////////
	while (s.Find("(")!=-1)
	{
		pos=s.Find("(");
		if (s.GetAt(pos+1)==')')
		{
			return false;
		}
		s.SetAt(pos,'!');
		i++;
	}
	while (s.Find(")")!=-1)
	{
		pos=s.Find(")");
		s.SetAt(pos,'!');
		if (s.GetAt(pos-1)=='(')
		{
			return false;
		}
		j++;
	}
	if (i!=j) return false;
    
	i=0;j=0;
	while (s.Find("[")!=-1)
	{
		pos=s.Find("[");
		if (s.GetAt(pos+1)==']')
		{
			return false;
		}
		s.SetAt(pos,'!');
		i++;
	}
	while (s.Find("]")!=-1)
	{
		pos=s.Find("]");
		if (s.GetAt(pos-1)=='[')
		{
			return false;
		}
		s.SetAt(pos,'!');
		j++;
	}
	if (i!=j) return false;
    //////////////////////////////
	s=str;
	while(IsContainSign(s))
	{
		int type,a,b,c,d;
		type=GetSignStyle(s,&a,&b,&c,&d);
		if (type==POW||type==LOG)
		{
			CString st=GetStrFromStartAndEnd(s,c,d);
			if (st.Find(",")==-1)
			{
				return false;
			}
		}
		else
		{
			CString st=GetStrFromStartAndEnd(s,c,d);
			if (st.Find(",")!=-1)
			{
				return false;
			}
		}
		s=ReplaceBetweenPos(s,"@",a,d);
	}
	////////////////////////
/*
	str.Replace("X","@");
	str.Replace("Y","#");
	str.Replace("Z","$");
	str.MakeLower();
	str.Replace("@","X");
	str.Replace("#","Y");
	str.Replace("$","Z");*/
	str.Replace("E","2.71828");
	str.Replace("PI","3.1415926");
	return true;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品成人免费在线| 日韩精品一区在线| 日韩一区二区免费视频| 首页国产丝袜综合| 欧美色中文字幕| 亚洲国产乱码最新视频 | 国产亚洲一区二区三区在线观看| 亚洲成年人影院| 成人免费av资源| 日本一区二区免费在线观看视频| 韩国女主播成人在线观看| 91国偷自产一区二区开放时间| 久久久久免费观看| 国产一区二区美女| 久久久久久**毛片大全| 国产一区 二区 三区一级| 久久精品人人爽人人爽| 国产电影一区在线| 日韩欧美在线一区二区三区| 捆绑调教一区二区三区| 欧美成人一区二区| 激情小说亚洲一区| 国产精品婷婷午夜在线观看| 99久久久久免费精品国产| 亚洲欧洲精品成人久久奇米网| 91美女片黄在线观看| 亚洲一区二区欧美| 日韩一级二级三级精品视频| 国产精品自在欧美一区| 国产精品久久久久久久午夜片| 91啪九色porn原创视频在线观看| 亚洲国产美女搞黄色| 欧美一区二区久久| 国产一区视频网站| 久久欧美中文字幕| 国产精品一区二区三区99| 亚洲视频在线一区| 制服.丝袜.亚洲.另类.中文| 久久99国产精品尤物| 国产精品乱码一区二区三区软件 | 欧美日韩精品欧美日韩精品| 久久99热这里只有精品| 国产精品欧美一级免费| 欧美日韩在线不卡| 日韩av二区在线播放| 26uuu另类欧美| 国产成人无遮挡在线视频| 亚洲一区二区三区不卡国产欧美| 欧美成人video| 97精品久久久午夜一区二区三区 | 日韩激情在线观看| 久久久国产综合精品女国产盗摄| 在线观看网站黄不卡| 国内欧美视频一区二区| 亚洲欧美日韩在线| 精品久久久久av影院| 色94色欧美sute亚洲线路一久 | 欧美色图一区二区三区| 国产精品久久福利| 欧美这里有精品| 国产精品一区二区久久不卡| 亚洲激情网站免费观看| 亚洲国产精品成人久久综合一区| 在线观看免费亚洲| 国内不卡的二区三区中文字幕| 亚洲女同ⅹxx女同tv| 久久久久久久久蜜桃| 欧美自拍偷拍午夜视频| 日韩av电影免费观看高清完整版| 亚洲精品视频在线| 欧美大片日本大片免费观看| 在线观看视频一区| 97久久精品人人做人人爽| 蜜臂av日日欢夜夜爽一区| 亚洲色图一区二区三区| 久久蜜桃av一区二区天堂 | 日韩视频免费直播| 91香蕉视频在线| 日本欧美一区二区| 一区二区欧美精品| 国产精品久久久久久久久免费丝袜| 日韩免费看的电影| 欧美三级视频在线| 色狠狠综合天天综合综合| 国产91清纯白嫩初高中在线观看| 精品一区二区三区在线观看 | 欧美午夜不卡在线观看免费| 99精品国产99久久久久久白柏| 国产露脸91国语对白| 免费在线观看不卡| 日本欧美大码aⅴ在线播放| 亚洲色图视频网| 国产亚洲综合av| 久久久国产精品不卡| 精品国产伦一区二区三区免费| 日韩午夜av电影| 91麻豆精品国产综合久久久久久 | 蜜桃一区二区三区四区| 亚洲成人av在线电影| 夜夜操天天操亚洲| 最新热久久免费视频| 国产精品国产馆在线真实露脸| 国产精品久久久久久久久免费桃花| 国产精品看片你懂得| 欧美国产乱子伦| 国产精品国产a| 亚洲免费成人av| 亚洲一区在线电影| 亚洲精品成a人| 偷拍与自拍一区| 免费在线视频一区| 国产一区二区免费视频| 成人免费电影视频| 色婷婷综合久色| 88在线观看91蜜桃国自产| 日韩欧美专区在线| 日韩欧美一级特黄在线播放| 欧美xxxx老人做受| 欧美激情综合五月色丁香小说| 成人免费一区二区三区在线观看| 亚洲欧美视频一区| 日韩av一区二| 成人综合在线视频| 欧美日韩中文另类| 717成人午夜免费福利电影| 欧美videofree性高清杂交| 国产亚洲1区2区3区| 亚洲免费观看高清完整版在线观看熊| 亚欧色一区w666天堂| 激情图片小说一区| 91免费在线播放| 日韩午夜激情电影| 久久人人97超碰com| 国产精品二三区| 五月天久久比比资源色| 国产精品一区在线观看乱码| 日本道免费精品一区二区三区| 欧美一区二区女人| 国产精品护士白丝一区av| 婷婷成人综合网| 色诱视频网站一区| 中文字幕精品一区| 久久99精品一区二区三区| 欧美高清视频不卡网| 亚洲人成精品久久久久| 国产黄色精品视频| 精品国产区一区| 美女国产一区二区| 欧美日韩国产高清一区二区三区| 亚洲精品乱码久久久久久| 成人av网站在线观看| 久久久蜜臀国产一区二区| 日韩黄色片在线观看| 欧美日韩国产精品自在自线| 一区二区三区鲁丝不卡| 成人黄色小视频| 欧美激情综合五月色丁香| 国产精品一区一区三区| 久久午夜色播影院免费高清| 久久99国产精品久久| 日韩欧美一二区| 老司机精品视频导航| 精品少妇一区二区三区| 久久国产精品露脸对白| 日韩欧美你懂的| 韩国av一区二区| 久久噜噜亚洲综合| 国产精品乡下勾搭老头1| 国产欧美精品在线观看| 国产成人啪免费观看软件| 国产欧美日韩综合精品一区二区| 成人中文字幕在线| 国产精品久久久久久一区二区三区| 菠萝蜜视频在线观看一区| 亚洲欧洲成人精品av97| 色婷婷av一区二区三区之一色屋| 亚洲精品视频一区二区| 欧美日韩国产精选| 美日韩一区二区| 久久久国产综合精品女国产盗摄| 国产福利91精品一区二区三区| 国产精品国产三级国产aⅴ中文 | 精品视频色一区| 青娱乐精品视频| 欧美精品一区二区三区久久久| 成人性生交大片免费看中文网站| 国产精品二三区| 欧美日韩中字一区| 精品一区二区三区香蕉蜜桃| 亚洲国产精品传媒在线观看| 色综合久久久久综合体| 五月天激情综合| 精品精品国产高清a毛片牛牛| 成人午夜视频在线| 亚洲电影欧美电影有声小说| 欧美不卡在线视频| 99精品视频一区二区| 日本亚洲三级在线| 久久久综合网站| 91免费在线视频观看|