鱼C论坛

 找回密码
 立即注册
查看: 5222|回复: 20

[技术交流] 贴一个我写的RPN算法,欢迎交流

[复制链接]
发表于 2014-1-23 23:43:04 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 qq1205470086 于 2014-1-23 23:50 编辑

大一寒假在家自学数据结构,刚好看到小甲鱼老师发布的这个教程,很开心!
刚看到后缀表达式这个地方,贴一个我写的代码,欢迎交流!
希望鱼C论坛越办越好!!!
  1. #include <string>
  2. #include <sstream>
  3. #include <stack>
  4. #include <map>
  5. #include <iostream>
  6. #include <algorithm>
  7. #include <functional>
  8. using namespace std;
  9. //中缀表达式转后缀表达式
  10. void convert(const char* source, string& result){
  11.         map<char,int> priority;
  12.         priority['+']=1; priority['-']=2; priority['*']=3; priority['/']=4;
  13.         string sou(source),res(result),str;
  14.         stringstream strstream(sou);
  15.         stack<char> st;
  16.         char c;
  17.         while(strstream>>c){
  18.                 if(isdigit(c)||c=='.')        result.append(&c,1);
  19.                 else if(c==')'){
  20.                         result.append(" ");
  21.                         while(st.top()!='('){
  22.                                 result.append(string(" ")+st.top()+string(" "));
  23.                                 st.pop();
  24.                         }
  25.                         st.pop();
  26.                 }else if(c=='('){ st.push(c); result.append(" ");}
  27.                 else{
  28.                         if(!st.empty()&&priority[st.top()]>=priority[c]){
  29.                                 result.append(string(" ")+st.top()+string(" "));
  30.                                 st.pop();
  31.                         }
  32.                         st.push(c);
  33.                         result.append(" ");
  34.                 }
  35.         }
  36.         while(!st.empty()){
  37.                 result.append(string(" ")+st.top());
  38.                 st.pop();
  39.         }
  40.         stringstream restream(result);
  41.         result.clear();
  42.         while(restream>>str) result.append(str+" ");
  43. }
  44. //计算后缀表达式
  45. double calc(const char* expr){
  46.         string str(expr);
  47.         stringstream exprstream(str);
  48.         stack<double> st;
  49.         string c;
  50.         while(exprstream>>c){
  51.                 if(c!="+"&&c!="-"&&c!="*"&&c!="/") st.push(atof(c.c_str()));
  52.                 else{
  53.                         double x,y;
  54.                         x=st.top(); st.pop();
  55.                         y=st.top(); st.pop();
  56.                         if(c=="+") st.push(y+x);
  57.                         else if(c=="-") st.push(y-x);
  58.                         else if(c=="*") st.push(y*x);
  59.                         else st.push(y/x);
  60.                 }
  61.         }
  62.         return st.top();
  63. }

  64. int _tmain(int argc, _TCHAR* argv[]){
  65.         string str,res;
  66.         getline(cin,str);
  67.         if(!str.empty()){
  68.                 str.erase(remove_if(str.begin(),str.end(),bind2nd(std::equal_to<char>(),' ')),str.end());
  69.                 convert(str.c_str(),res);
  70.                 cout<<res<<endl;
  71.                 cout<<calc(res.c_str())<<endl;
  72.         }
  73.         return 0;
  74. }
复制代码

评分

参与人数 1荣誉 +5 鱼币 +5 贡献 +5 收起 理由
小甲鱼 + 5 + 5 + 5 不错,继续加油!

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2014-1-24 00:12:04 | 显示全部楼层
这个用户名可不可以改。。。我以为只是登陆用的呢。。。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-1-24 01:02:13 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-1-24 01:06:48 | 显示全部楼层
小甲鱼 发表于 2014-1-24 01:02
论坛不支持修改用户名哦~

本尊驾到,不胜荣幸{:1_1:}
教程非常不错{:1_1:}
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-1-24 15:15:09 | 显示全部楼层
qq1205470086 发表于 2014-1-24 01:06
本尊驾到,不胜荣幸
教程非常不错

{:7_157:}大家一起学习共勉!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-1-24 21:36:59 | 显示全部楼层
很好很好啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-1-24 21:56:18 | 显示全部楼层
很好很好啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-1-25 03:54:49 | 显示全部楼层
看了下你的后缀表达式的计算,逻辑很清晰,确实不错。不过,建议你写程序的时候,多写些注释,方便其他人读你的程序,也方便你以后再看自己写的东西。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-1-25 20:31:31 | 显示全部楼层
故乡的风 发表于 2014-1-25 03:54
看了下你的后缀表达式的计算,逻辑很清晰,确实不错。不过,建议你写程序的时候,多写些注释,方便其他人读 ...

好的,谢谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-1-29 04:57:08 From FishC Mobile | 显示全部楼层
感谢楼主分享
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-2-1 23:44:23 | 显示全部楼层
激动人心,无法言表!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-2-11 09:44:49 | 显示全部楼层
学习了
很好的帖子
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-2-28 11:48:52 | 显示全部楼层
太长了吧,不过我最喜欢这种帖子了,好东东
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-2-28 12:17:28 | 显示全部楼层
楼主好厉害啊!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-8-12 10:09:00 | 显示全部楼层
谢谢楼主分享!!!!!!!!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-8-13 15:33:24 | 显示全部楼层
谢谢LZ分享
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-8-16 11:34:03 From FishC Mobile | 显示全部楼层
回帖是一种美德
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-8-20 09:12:46 | 显示全部楼层
我也才刚刚学习数据结构,收藏先!!!!!!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-9-10 18:46:28 | 显示全部楼层
谢谢喽组分享
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-10-4 18:04:52 | 显示全部楼层
学习一下。。。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-13 01:43

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表