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

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

?? calculator.cpp

?? 實現多項式表達式的運算器利用棧實現表達式計算器的模板類;用表達式計算器類和多項式類實現多項式表達式的計算器
?? CPP
字號:
#include<iostream.h>
#include<string.h>
#include<stdlib.h>
#include<conio.h>
#include"stack.hpp"
#include"namedpolynomial.hpp"


template<class Type>
class Calculator
{
public:
	Calculator(){}//Constructor
	void Run();   //多項式的執行函數
	void Clear(); //清空運算數棧s中的內容
private:
	void getOperand();//取得計算器要運算的多項式
	bool isOperator(char ch);//判斷輸入的字符是否為運算符
	bool isIdentifier(char ch);//判斷輸入的字符是否合法的標識符
	void postfix(char p[],char q[]);//將中序表達式轉化為后續表達式
	int icp(char ch);//判斷一個運算符的棧外優先數
	int isp(char ch);//判斷一個運算符的棧內優先數
	void AddOperand(Type value);//運算數進棧
	bool Get2Operands(Type& left, Type& right);//從運算數棧中取兩個運算數作運算
	void DoOperator(char op);//作運算
	
	Stack<Type> s;//暫存運算數的堆棧
	Type* operand;//用戶輸入的運算運算數數組,運算數堆棧將從這里取得符合要求的運算數進棧
	int operandscount;//計算某次計算中計算器總共有幾個不同運算數
};

//////////////////////////////////////////////////////////////////////
template<class Type>
void Calculator<Type>::AddOperand(Type value)
{
	//運算數進棧
	s.Push(value);
}
//////////////////////////////////////////////////////////////////////
template<class Type>
bool Calculator<Type>::Get2Operands(Type& left,Type& right) 
{
	//從運算數棧中取兩個運算數作運算
	if(s.IsEmpty())
	{
		cerr<<"Missing Operand!"<<endl;
		return false;
	}
	right = s.Pop();
	if(s.IsEmpty())
	{
		cerr<<"Missing Operand!"<<endl;
		return false;
	}
	left=s.Pop();
	return true;
}
//////////////////////////////////////////////////////////////////////
template<class Type>
void Calculator<Type>::DoOperator(char op)
{
	Type left, right;
	bool result;
	result=Get2Operands(left,right);
	if(result == true)
	switch(op)
	{
		case '+':  { s.Push(left+right);  break; }
		case '-':  { s.Push(left-right);  break; }
		case '*':  { s.Push(left*right);  break; }
		default:   
			{
				cerr<<"Error!This operation is not defined!"<<endl;
				Clear();
				exit(1);
			}
	}
	else
		Clear();
}
//////////////////////////////////////////////////////////////////////
template<class Type>
void Calculator<Type>::Clear()
{
	s.MakeEmpty();
}
//////////////////////////////////////////////////////////////////////
template<class Type>
int Calculator<Type>::icp(char ch)
{
	//輸出運算符的棧外優先數
	switch (ch)
	{
	    case '=':  return 0;
        case '(':  return 8;
        case '^':  return 6;
        case '*':  
		case '/':  
		case '%': return 4;
        case '+':   
		case '-': return 2;
        case ')': return 1;
    }
	return -1;
}
//////////////////////////////////////////////////////////////////////
template<class Type>
int Calculator<Type>::isp(char ch)
{  
	//輸出運算符的棧內優先數
    switch (ch)
	{
        case '=':  return 0;
        case '(':  return 1;
        case '^':  return 7;
        case '*':  
		case '/':  
		case '%':  return 5;
        case '+':  
		case '-':  return 3;
        case ')':  return 8;
    }
	return -1;
}
//////////////////////////////////////////////////////////////////////
template<class Type>
void Calculator<Type>::Run()
{
	//數組p存放轉化后的后序表達式,q存放原來的中序表達式
	char p[100],q[100];
	getOperand();//先取得所作運算的運算對象
	
	//提示用戶輸入運算對象之間的運算表達式
	cout<<"請輸入所要作的運算的表達式:"<<endl;
	
	//postfix函數將讀入運算的中序表達式,并將它轉化為相應的后序表達式
	//在轉化后的后序表達式中,運算對象之間,運算對象與運算符之間用空格
	//分開,以便下面的while循環解析不同的多項式名,從而在operand數組中取得
	//所需要的運算多項式
	postfix(p,q);

	while( (p[0] != '=') && (p[0]!='\0'))//掃描后序多項式,'='為運算結束標志
	{
		int n=strlen(p);//求得后序多項式字符串的長度
		//如果串的首字符是'+' '-' '*'之一,則執行已經運算
		if( (p[0] == '+') || (p[0] == '-') || (p[0] == '*'))
		{
			DoOperator(p[0]);//執行運算
			//當前運算已完成,將后序表達式串中的內容前移,消去已做的運算符
			//即將字符串中后面n-1個字符(除去已上面已做的運算的運算符)復制到
			//字符串前面
			strncpy(p,p+1,n-1);
		}

		//如果串的首字符是標識符,在operand數組中搜索名字與當前后序
		//表達式的運算對象名字一致的多項式,并執行讀取運算數入棧的工作
		else if( isIdentifier(p[0]) )
		{
			//字符數組記錄當前后序表達式的運算對象的名字
			char* m=new char[100];
			
			//以下語句段將當前后序表達式的運算對象的名字復制到字符串m中
			m[0] = p[0];
			for(int i=1;p[i]!=' ';i++)
				m[i]=p[i];
			m[i]='\0';
			//用m串創建一個String對象
			String s=m;

            //在operand數組中搜索名字與當前后序表達式的運算對象名字
		    //一致的多項式,并執行讀取運算數入棧的工作
			for(int j=0;j<operandscount;j++)
			{
				if( s==operand[j].getName() )
					AddOperand(operand[j]);
			}

			strncpy(p,p+i+1,n-i-1);//當前運算已完成,將后序表達式串中的內
			//容前移,移除已進棧的運算數即將字符串中后面n-i-1個字符(除去已
			//上面已進棧的運算數)復制到字符串前面
		}
		else
		{
			cerr<<"Error!Unknown charactor "<<p[0]<<"!The Calculator can't do it!"<<endl;
			exit(1);
		}
	}
	assert(!s.IsEmpty());//若棧底無數,錯誤!終止
	cout<<"結果多項式:"<<endl;
	cout<<q<<"="<< s.Pop().getPoly()<<endl;//輸出結果(棧底元素)
}
//////////////////////////////////////////////////////////////////////
template<class Type>
void Calculator<Type>::postfix(char p[],char q[])
{
	//將中序表達式轉化為后續表達式,轉化后的后序表達式存于數組p中轉化前
	//的中序表達式存放于q中,兩個數組返回Run中繼續執行計算器的運算
	
	Stack<char> s;//存放運算符的堆棧
	char ch,y;
	int i=0,j=0;//數組p和q的計數器
	s.MakeEmpty();
	s.Push('=');//先將等號進棧
	
	//輸入中序表達式,以'='為結束標志
	while(cin>>ch,ch!='=')
	{
		q[j++]=ch;//記錄中序表達式的內容進數組q
		//判斷輸入的字符,如果是合法的表示符類型,直接將它記入數組p中
		if(isIdentifier(ch))
		{
			p[i]=ch;
			i++;
		}
		//如果輸入字符是')'
		else if(ch==')')
		{
			//首先判斷數組p中的最后一個字符是否表示符,如果是則插入空格
			//以便將計算對象-多項式的名字與運算符分隔開
			if(isIdentifier(p[i-1]))
			{
				p[i]=' ';
				i++;
			}
			//連續從運算符棧中退出運算符,直至'('為止
			for(y=s.GetTop();y!='(';y=s.GetTop())
			{
				s.Pop();
				p[i]=y;
				i++;
			}
			s.Pop();//最后將'('也從棧中退出
		}
		
		//如果輸入的字符是運算符
		else if(isOperator(ch))
		{
			//如果該運算符是'(',并且數組p中的最后一個字符是標識符
			//則在p數組中插入一個空格作為分隔
			if((ch!='(') && isIdentifier(p[i-1]))
			{
				p[i]=' ';
				i++;
			}

			//改運算符是其他類型,比較運算符棧的棧頂元素與當前輸入的運算符
			//的優先數,如果棧頂運算符的isp大于當前輸入字符的icp,則不斷從
			//棧中退出運算符,直至棧頂運算符的isp>當前輸入運算符的icp為止
			for(y=s.GetTop();isp(y)>icp(ch);y=s.GetTop())
			{
				s.Pop();
				p[i]=y;
				i++;
			}
			//最后當棧頂運算符的isp不再大于當前輸入字符的icp,則將ch進棧
			s.Push(ch);
		}
		else //否則輸入字符不合法,提示并中止程序
		{
			cerr<<"Error!未知字符 "<<ch<<" 被輸入!運算器無法完成計算!"<<endl;
			exit(1);
		}
	}
	//判斷數組p中的最后一個字符是否表示符,如果是則插入空格
	if(isIdentifier(p[i-1]))
	{
		p[i]=' ';
		i++;
	}
	//最后從運算符棧中連續退出運算符存入p數組中,以完成后序表達式的轉換
	while(!s.IsEmpty())
	{
		y=s.Pop();
		p[i]=y;
		i++;
	}
	//為p和q數組加上字符串結束符
	q[j]='\0';
	p[i]='\0';
}
//////////////////////////////////////////////////////////////////////
template<class Type>
bool Calculator<Type>::isIdentifier(char ch)
{
	//判斷輸入的字符是否合法的標識符,合法的表示符由數字,字母和下劃線組成
	if( ((ch>='a')&&(ch<='z')) || ((ch>='A')&&(ch<='Z')) || ((ch>='0')&&(ch<='9'))||(ch=='_'))
		return true;
	else 
		return false;
}
//////////////////////////////////////////////////////////////////////
template<class Type>
bool Calculator<Type>::isOperator(char ch)
{
	//判斷輸入的字符是否為運算符
	switch(ch)
	{
	case '+':
	case '-':
	case '*':
	case '(':
	case ')':return true;
	}
	return false;
}
//////////////////////////////////////////////////////////////////////
template<class Type>
void Calculator<Type>::getOperand()
{
	//取得計算器要運算的多項式
	cout<<"您總共需要輸入多少個多項式作為計算對象?請輸入:"<<endl;
	cin>>operandscount;
	operand=new namedPolynomial[operandscount];
	
	for(int i=1;i<=operandscount;i++)
	{
		cout<<"輸入多項式"<<i<<":"<<endl;
		cin>>operand[i-1];
	}
	
}
//////////////////////////////////////////////////////////////////////
//主函數
void main()
{
	cout<<"本程序為多項式計算器。用于完成多項式的加,減,乘等多項式的復合運算。"<<endl;
	cout<<endl;
	cout<<endl;
	cout<<"程序即將開始。若要啟動多項式計算器請按任意鍵。"<<endl;
	cout<<endl;
	cout<<endl;
	getch();

	char y='y';
	while(y=='y')
	{
		Calculator<namedPolynomial> a;
	    a.Run();
		cout<<endl;
		cout<<endl;
		cout<<"需要繼續做其他多項式運算嗎?y-繼續,n-退出。請輸入你的選擇:"<<endl;
		cin>>y;
	}

	cout<<endl;
	cout<<endl;
	getch();
	cout<<"多項式計算器程序結束!感謝使用!"<<endl;
	cout<<endl;
	cout<<endl;
}





?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产网红主播福利一区二区| 欧美日韩中文另类| 免费人成黄页网站在线一区二区| 国产亚洲欧美一区在线观看| 日韩欧美黄色影院| 91精品国产一区二区三区蜜臀| 在线日韩一区二区| 在线观看成人小视频| 91免费视频网| 在线免费观看不卡av| 91麻豆国产精品久久| 色哟哟亚洲精品| 91高清视频在线| 91福利视频在线| 欧美三区免费完整视频在线观看| 99免费精品视频| 91美女视频网站| 欧美日韩国产三级| 欧美日韩国产高清一区二区三区 | 欧美日韩视频在线观看一区二区三区 | 久久久久97国产精华液好用吗| 日韩一区二区三区三四区视频在线观看 | 日本美女一区二区三区| 蜜桃av噜噜一区二区三区小说| 日韩和欧美一区二区三区| 日韩和欧美一区二区三区| 久久国产精品第一页| 国产成人午夜高潮毛片| 91香蕉国产在线观看软件| 欧美视频三区在线播放| 91麻豆精品国产91久久久| 久久免费国产精品| 亚洲欧美日韩综合aⅴ视频| 午夜精品福利视频网站| 国产一区免费电影| 91浏览器打开| 日韩免费福利电影在线观看| 亚洲丝袜美腿综合| 亚洲午夜激情av| 狠狠色丁香久久婷婷综合丁香| 懂色av一区二区三区免费观看| 欧美性受xxxx黑人xyx| 久久网这里都是精品| 亚洲欧美成人一区二区三区| 久久se精品一区二区| 91玉足脚交白嫩脚丫在线播放| 欧美麻豆精品久久久久久| 国产免费观看久久| 五月婷婷综合在线| 菠萝蜜视频在线观看一区| 日韩精品一区二区三区在线播放 | 中文字幕国产一区二区| 亚洲第一av色| 菠萝蜜视频在线观看一区| 91精品国产综合久久福利| 自拍av一区二区三区| 国产在线精品一区二区三区不卡| 欧洲日韩一区二区三区| 日本一区二区三区高清不卡| 日本不卡高清视频| 色婷婷激情综合| 国产偷国产偷精品高清尤物| 日韩视频国产视频| 国产欧美视频一区二区三区| 五月婷婷久久综合| 99在线视频精品| 欧美xfplay| 免费高清在线一区| 在线一区二区视频| 亚洲欧洲精品一区二区三区不卡| 美女视频黄 久久| 51久久夜色精品国产麻豆| 亚洲精品免费在线| 成人三级在线视频| 中文字幕不卡一区| 国产成人在线网站| 国产视频在线观看一区二区三区| 婷婷亚洲久悠悠色悠在线播放 | 日韩精品中午字幕| 奇米色777欧美一区二区| 欧美久久免费观看| 婷婷开心激情综合| 欧美日韩成人一区二区| 亚洲成年人网站在线观看| 欧美午夜精品电影| 五月天亚洲婷婷| 欧美一二区视频| 久久av资源站| 国产亚洲人成网站| 成人免费精品视频| 亚洲欧美激情插| 欧美日韩一区不卡| 五月天中文字幕一区二区| 日韩一区二区在线看片| 精品一二三四区| 中文字幕第一页久久| 北条麻妃国产九九精品视频| 青青草国产精品亚洲专区无| 欧美一级日韩不卡播放免费| 老色鬼精品视频在线观看播放| 欧美成人精品二区三区99精品| 国产美女一区二区三区| 国产欧美精品一区二区三区四区| 99久久99久久免费精品蜜臀| 综合婷婷亚洲小说| 欧美日韩精品电影| 韩国在线一区二区| 中文字幕日本乱码精品影院| 欧洲中文字幕精品| 久久精品99国产精品| 欧美国产一区二区在线观看| 日本久久电影网| 看片的网站亚洲| 亚洲欧洲综合另类在线| 欧美一级日韩免费不卡| 成人性生交大合| 无码av免费一区二区三区试看| 久久久综合视频| 91国在线观看| 国产成人精品影院| 亚洲国产综合色| 日本一区二区综合亚洲| 欧美日韩国产123区| 丁香婷婷综合激情五月色| 偷拍自拍另类欧美| 中文字幕色av一区二区三区| 日韩欧美激情四射| 在线一区二区三区做爰视频网站| 精品亚洲成a人| 性欧美疯狂xxxxbbbb| 中文字幕av不卡| 欧美一激情一区二区三区| av激情成人网| 国内成人精品2018免费看| 夜夜嗨av一区二区三区| 久久久亚洲国产美女国产盗摄| 欧美撒尿777hd撒尿| 成人动漫中文字幕| 狠狠狠色丁香婷婷综合久久五月| 亚洲成人午夜电影| 亚洲男人的天堂在线观看| 欧美tk丨vk视频| 555www色欧美视频| 欧美日韩在线综合| 色婷婷久久99综合精品jk白丝| 国产精品一二三区在线| 久久99久久精品| 丝袜美腿亚洲色图| 亚洲午夜国产一区99re久久| 中文字幕日韩av资源站| 中文字幕第一区二区| 久久久久久久久蜜桃| 欧美国产一区在线| 久久亚洲一区二区三区明星换脸| 日韩一区二区在线播放| 欧美日韩精品一区二区三区蜜桃| 97精品久久久午夜一区二区三区| 国产资源在线一区| 国产美女视频一区| 国产高清不卡二三区| 国产福利一区二区| 国产成人一级电影| 不卡的av电影| 色狠狠av一区二区三区| 日本高清不卡一区| 欧美三日本三级三级在线播放| 欧美午夜免费电影| 欧美精品欧美精品系列| 欧美精品色一区二区三区| 在线不卡一区二区| 日韩三级中文字幕| 久久亚洲精品国产精品紫薇| 精品日产卡一卡二卡麻豆| 精品成人一区二区三区四区| 久久精品欧美一区二区三区不卡| 国产喂奶挤奶一区二区三区| 国产精品理论片在线观看| 亚洲免费观看高清完整版在线| 有码一区二区三区| 日本午夜精品一区二区三区电影| 免费不卡在线观看| 国产成人综合网| 在线视频你懂得一区| 欧美精品18+| 久久久美女毛片| 亚洲欧美福利一区二区| 日韩精品乱码av一区二区| 国产麻豆91精品| 91麻豆福利精品推荐| 日韩亚洲欧美高清| 亚洲欧洲在线观看av| 五月天欧美精品| 成人黄页毛片网站| 欧美肥妇free| 国产精品每日更新| 青娱乐精品视频在线| 99精品视频中文字幕| 日韩欧美一级精品久久| 中文字幕一区二区三区视频 | 欧美三级乱人伦电影|