zoukankan      html  css  js  c++  java
  • stack应用-ccf201903-2二十四点

    题目背景

    二十四点:使用 3 个加减乘除运算使得 4张纸牌上数字的运算结果为 24。

    题目描述

    定义每一个游戏由 4 个从 1-9 的数字和 3个四则运算符组成,保证四则运算符将数字两两隔开,不存在括号和其他字符,运算顺序按照四则运算顺序进行。

    其中加法用符号 + 表示,减法用符号 -表示,乘法用小写字母 x 表示,除法用符号 / 表示。在游戏里除法为整除,例如 2 / 3 = 0,3 / 2 = 1, 4 / 2 = 2。
    老师给了你 n 个游戏的解,请你编写程序验证每个游戏的结果是否为 24 。

    输入格式

    从标准输入读入数据。

    第一行输入一个整数 n,从第 2 行开始到第 n + 1 行中,每一行包含一个长度为 7的字符串,为上述的 24 点游戏,保证数据格式合法。

    输出格式

    输出到标准输出。 包含 n 行,对于每一个游戏,如果其结果为 24 则输出字符串 Yes,否则输出字符串 No。

    样例输入

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    10
    9+3+4x3
    5+4x5x5
    7-9-9+8
    5x6/5x4
    3+5+7+9
    1x1+9-9
    1x9-5/9
    8/5+6x9
    6x7-3x6
    6x4+4/5

    样例输出

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Yes
    No
    No
    Yes
    Yes
    No
    No
    No
    Yes
    Yes

    分析

    使用stack。

    先读入第一个数字,入栈。

    然后是3次循环,每次循环读一个符号和一个数字。

    在一次循环中,读的符号若为 x 或 / ,则弹出栈顶数字,将其与下一位数字作相应运算后再入栈;读的符号若为 + 或 - ,则下一位数字直接入栈,注意:若符号为 - ,入栈时入的是相反数(便于最后一次性相加)。

    循环结束后,将栈内剩余的数字依次弹出相加。若为24,则Yes。

    Code

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    < 大专栏  stack应用-ccf201903-2二十四点span class="line">26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54

    using namespace std;

    int (){

    int n;
    cin>>n;
    while(n--){
    stack<int> s;
    int a,b;

    cin>>a;
    s.push(a);


    for(int i=0;i<3;i++){
    //读一个符号
    char c;
    cin>>c;
    //读一个数字
    cin>>a;
    int sum; //sum存储乘除运算的中间结果
    if(c=='x'){
    sum=a*s.top();
    s.pop();
    s.push(sum);
    }
    else if(c=='/') {
    sum=s.top()/a;
    s.pop();
    s.push(sum);
    }
    else if(c=='+'){
    s.push(a);
    }
    else{
    s.push(a*(-1));
    }
    }
    int count=0;
    while (!s.empty()){
    count+=s.top(); //依次弹出相加
    s.pop();
    }
    //cout<<count<<endl;
    if(count==24){
    cout<<"Yes"<<endl;
    }
    else{
    cout<<"No"<<endl;
    }
    }
    return 0;
    }
  • 相关阅读:
    怎样删除数据库中的反复记录?
    GitHub上最受欢迎的Android开源项目TOP20
    hdu2066一个人的旅行
    《Head First 设计模式》学习笔记——模板方法模式
    C语言盲点笔记1
    北大光华管理学院院长蔡洪滨:商学院需要有灵魂_网易财经
    戴修宪_百度百科
    [对话CTO]当当网熊长青:兴趣是成为优秀工程师的第一因素-CSDN.NET
    【网络金融部团队及负责人,太平洋证券股份有限公司】前程无忧官方招聘网站
    辞职穷半年,转行穷三年!!
  • 原文地址:https://www.cnblogs.com/lijianming180/p/12433044.html
Copyright © 2011-2022 走看看