加入收藏 收藏网站 设为首页 设为首页
招生考试网
学历类| 阳光高考 研 究 生 自学考试 成人高考 专 升 本 中考会考 外语类| 四 六 级 职称英语 商务英语 公共英语 日语能力
资格类| 公 务 员 报 关 员 银行从业 司法考试 导 游 证 教师资格 财会类| 会 计 证 经 济 师 会计职称 注册会计 税 务 师
工程类| 一级建造 二级建造 造 价 师 造 价 员 咨 询 师 监 理 师 医学类| 卫生资格 执业医师 执业药师 执业护士 国际护士
计算机| 等级考试 软件水平 应用能力 其它类| 书画等级 美国高考 驾 驶 员 书法等级 少儿英语 报 检 员 单 证 员 出国留学
 招生考试网 - 计算机等级考试 - 考试辅导 - 计算机二级 - 正文

 
C++编写24程序
来源:fjzsksw.com 2010-4-28 编辑:zhoupanyu 【字体:小 大】

 

  今天在csdn student 大本营看到了一个人家写的24程序,感觉人家的思路非常清晰,于是自己也着手写了一个,顺便温习了一下标准c++。在我的程序中,使用了 stringstream类做parse,后缀表达式穷举所有可行解,而用中缀表达式计算用户输入的表达式。因为比较懒,当用户算不出来时,按出来的答案是个后缀表达式。 有关源代码如下:

  Token.h :用于Parse,以及操作符,优先级的定义

  01#ifndef TOKEN_H

  02#define TOKEN_H

  03enum Token_type {Numeric = 0,Op};

  04enum Operator{ADD_OPR = 0,MINUS_OPR,

  05MUL_OPR,DIV_OPR,

  06LEFT_BRA,RIGHT_BRA,

  07TER};

  08enum PRI{HIGHER = 0,LOWER,EQUAL,NO_POSSIBLE};

  09class Token

  10{

  11public:

  12    Token(Token_type _type,double _x,Operator _op):type(_type),

  13        x(_x),op(_op){}

  14    Token_type type;

  15    double x;

  16    Operator op;

  17};

  18void Parse(string expression,vector<Token>& tokens);

  19bool isOp(char c);

  20#endif

  Token.cpp

  01#include <string>

  02#include <vector>

  03#include <sstream>

  04using namespace std;

  05#include "Token.h"

  06extern int OpTypeNum;

  07char operators[7] = {'+','-','*','/','(',')','#'};

  08

  09bool isOp(char c,int &index)

  10{

  11    for (int i = 0;i < OpTypeNum;i++)

  12    {

  13        if (c == operators[i])

  14        {

  15            index = i;

  16            return true;

  17        }

  18    }

  19    return false;

  20}

  21void Parse(string expression,vector<Token>& tokens)

  22{

  23    stringstream ss (stringstream::in | stringstream::out);

  24    ss << expression;

  25    char c;

  26    int val,index;

  27    while (ss >> c)

  28    {

  29        if (isdigit(c))

  30        {

  31            ss.putback(c);

  32            ss >> val;

  33            tokens.push_back(Token(Numeric,val,Operator(0)));

  34        }else if (isOp(c,index))

  35            tokens.push_back(Token(Op,-1,Operator(index)));

  36    }

  37}

  ExpCalc.h 用堆栈实现的中缀和后缀表达式的计算

  01#ifndef EXPCALC_H

  02#define EXPCALC_H

  03class ExpCalc

  04{

  05public:

  06    bool PostfixCalc(vector<double> &a,vector<Operator> &ops,double & res);

  07    bool infixCalc(vector<Token>& tokens,double& res);

  08    bool Calc(double x1,double x2,Operator op,double & res);

  09    void Clear();

  10private:

  11    bool doWhenHigher(Operator op);

  12    bool doWhenLower(Operator op,Operator nxt_op);

  13    bool doWhenEqual();

  14

  15    stack<double> operands_stack;

  16    stack<Operator> operators_stack;

  17};

  18#endif

  ExpCalc.cpp

  001#include <stack>

  002#include <vector>

  003#include <cmath>

  004using namespace std;

  005#include "Token.h"

  006#include "ExpCalc.h"

  007#include "24Game.h"

  008int OpTypeNum = 7;

 



 
  • 上一个文章:

  • 下一个文章:
  • 网站版权与免责声明
    ①由于各方面情况的不断调整与变化,本网所提供的相关信息请以权威部门公布的正式信息为准.
    ②本网转载的文/图等稿件出于非商业性目的,如转载稿涉及版权等问题,请在两周内来电联系.
    推荐文章
  • 此栏目下没有推荐文章
  • 热门文章

    报名考试
    全国 | 黑龙江 | 吉林 | 辽宁 | 内蒙古
    青海 | 宁夏 | 甘肃 | 新疆 | 陕西
    西藏 | 北京 | 天津 | 河北 | 山东
    江苏 | 安徽 | 河南 | 上海 | 浙江
    福建 | 广东 | 山西 | 湖南 | 湖北
    江西 | 广西 | 海南 | 云南 | 贵州
    四川 | 重庆
    分省高校计算机考试
    黑龙江 | 吉林 | 辽宁 | 内蒙古 | 河北
    北京 | 天津 | 新疆 | 甘肃 | 宁夏
    青海 | 陕西 | 山西 | 河南 | 山东
    江苏 | 安徽 | 浙江 | 福建 | 广东
    海南 | 广西 | 江西 | 湖北 | 湖南
    四川 | 上海 | 重庆 | 贵州 | 云南
    西藏
    成绩查询
    报考指南
    试题答案
    模拟试题
    考试辅导
    计算机一级 | 计算机二级 | 计算机三级 | 计算机四级
    经验交流
    高校计算机