![]() 图1: |
![]() 图2: |
![]() 图3: |
![]() 图4: |
![]() 图 5: |
![]() 图6: |
![]() 图7: |
![]() 图8: |
使用树的深度遍历即可算出最终的结果。
程序实现
本文,给出使用栈处理四则运算的C#实现方法,如下:
CalUtility.cs
using System;
namespace Calculate
{
/// <summary>
/// CalUtility 的摘要说明。
/// 读算式辅助工具
/// </summary>
public class CalUtility
{
System.Text.StringBuilder StrB;
private int iCurr=0;
private int iCount=0;
/// <summary>
/// 构造方法
/// </summary>
public CalUtility(string calStr)
{
StrB = new System.Text.StringBuilder(calStr.Trim());
iCount = System.Text.Encoding.Default.GetByteCount(calStr.Trim());
}
/// <summary>
/// 取段,自动分析数值或计算符
/// </summary>
/// <returns></returns>
public string getItem()
{
//结束了
if(iCurr==iCount)
return "";
char ChTmp = StrB[iCurr];
bool b=IsNum(ChTmp);
if(!b)
{
iCurr++;
return ChTmp.ToString();
}
string strTmp="";
while(IsNum(ChTmp)==b && iCurr<iCount)
{
ChTmp = StrB[iCurr];
if(IsNum(ChTmp)==b)
strTmp +=ChTmp;
else
break;
iCurr++;
}
return strTmp;
}
/// <summary>
/// 是否是数字
/// </summary>
/// <param name="c">内容</param>
/// <returns></returns>
public bool IsNum(char c)
{
if((c>=’0’ && c<=’9’)|| c==’.’)
{
return true;
}
else
{
return false;
}
}
/// <summary>
/// 是否是数字
/// </summary>
/// <param name="c">内容</param>
/// <returns></returns>
public bool IsNum(string c)
{
if(c.Equals(""))
return false;
if((c[0]>=’0’ && c[0]<=’9’)|| c[0]==’.’)
{
return true;
}
else
{
return false;
}
}
/// <summary>
/// 比较str1和str2两个运算符的优先级,ture表示str1高于str2,false表示str1低于str2
/// </summary>
/// <param name="str1">计算符1</param>
/// <param name="str2">计算符2</param>
/// <returns></returns>
public bool Compare(string str1,string str2)
{
return getPriority(str1)>=getPriority(str2);