鱼C论坛

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

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

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

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

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

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

大一寒假在家自学数据结构,刚好看到小甲鱼老师发布的这个教程,很开心!
刚看到后缀表达式这个地方,贴一个我写的代码,欢迎交流!
希望鱼C论坛越办越好!!!
#include <string>
#include <sstream>
#include <stack>
#include <map>
#include <iostream>
#include <algorithm>
#include <functional>
using namespace std;
//中缀表达式转后缀表达式
void convert(const char* source, string& result){
        map<char,int> priority;
        priority['+']=1; priority['-']=2; priority['*']=3; priority['/']=4;
        string sou(source),res(result),str;
        stringstream strstream(sou);
        stack<char> st;
        char c;
        while(strstream>>c){
                if(isdigit(c)||c=='.')        result.append(&c,1);
                else if(c==')'){
                        result.append(" ");
                        while(st.top()!='('){ 
                                result.append(string(" ")+st.top()+string(" "));
                                st.pop();
                        }
                        st.pop();
                }else if(c=='('){ st.push(c); result.append(" ");}
                else{
                        if(!st.empty()&&priority[st.top()]>=priority[c]){ 
                                result.append(string(" ")+st.top()+string(" ")); 
                                st.pop();
                        }
                        st.push(c);
                        result.append(" ");
                }
        }
        while(!st.empty()){ 
                result.append(string(" ")+st.top()); 
                st.pop(); 
        }
        stringstream restream(result);
        result.clear();
        while(restream>>str) result.append(str+" ");
}
//计算后缀表达式
double calc(const char* expr){
        string str(expr);
        stringstream exprstream(str);
        stack<double> st;
        string c;
        while(exprstream>>c){
                if(c!="+"&&c!="-"&&c!="*"&&c!="/") st.push(atof(c.c_str()));
                else{
                        double x,y;
                        x=st.top(); st.pop();
                        y=st.top(); st.pop();
                        if(c=="+") st.push(y+x);
                        else if(c=="-") st.push(y-x);
                        else if(c=="*") st.push(y*x);
                        else st.push(y/x);
                }
        }
        return st.top();
}

int _tmain(int argc, _TCHAR* argv[]){
        string str,res;
        getline(cin,str);
        if(!str.empty()){
                str.erase(remove_if(str.begin(),str.end(),bind2nd(std::equal_to<char>(),' ')),str.end());
                convert(str.c_str(),res);
                cout<<res<<endl;
                cout<<calc(res.c_str())<<endl;
        }
        return 0;
}

评分

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

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2014-1-24 00:12:04 | 显示全部楼层
这个用户名可不可以改。。。我以为只是登陆用的呢。。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-1-24 01:02:13 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本尊驾到,不胜荣幸{:1_1:}
教程非常不错{:1_1:}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

{:7_157:}大家一起学习共勉!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-1-24 21:36:59 | 显示全部楼层
很好很好啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-1-24 21:56:18 | 显示全部楼层
很好很好啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

使用道具 举报

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

好的,谢谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-1-29 04:57:08 From FishC Mobile | 显示全部楼层
感谢楼主分享
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-2-1 23:44:23 | 显示全部楼层
激动人心,无法言表!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-2-11 09:44:49 | 显示全部楼层
学习了
很好的帖子
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-2-28 11:48:52 | 显示全部楼层
太长了吧,不过我最喜欢这种帖子了,好东东
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-2-28 12:17:28 | 显示全部楼层
楼主好厉害啊!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-8-12 10:09:00 | 显示全部楼层
谢谢楼主分享!!!!!!!!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-8-13 15:33:24 | 显示全部楼层
谢谢LZ分享
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-8-16 11:34:03 From FishC Mobile | 显示全部楼层
回帖是一种美德
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-8-20 09:12:46 | 显示全部楼层
我也才刚刚学习数据结构,收藏先!!!!!!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-9-10 18:46:28 | 显示全部楼层
谢谢喽组分享
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-10-4 18:04:52 | 显示全部楼层
学习一下。。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-23 18:54

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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