当前位置: 首页 > news >正文

栈容器的应用

第一题:

用数组来模拟栈:

题解代码:

class Solution {
public:
    string removeDuplicates(string s) {

        // 用数组模拟栈
        string s1;
        for (int i = 0; i < s.size(); i++) {
            if(s1.size() == 0){
                s1+=s[i];
            }
            else if (s1.back() == s[i]) {
                s1.pop_back();
            } else
                s1 += s[i];
        }
        return s1;
    }
};

 第二题:

还是数组模拟栈

题解代码:

class Solution {
public:
    bool backspaceCompare(string s, string t) {
        //同样的用数组来模拟
        string s1,s2;
        for(const auto& e:s){
            //当不为空并且e == #时才尾删
            if(s1.size()&&e == '#'){
                s1.pop_back();
            }
            //不能将#也➕到串中
            else if(e != '#') s1+=e;
        }
        for(const auto& e:t){
            if(s2.size()&&e == '#'){
                s2.pop_back();
            }
            else if(e!='#')s2+=e;
        }
        return s1 == s2;
        // if(s1.size() == 0&&s2.size() == 0){
        //     return true;
        // }
        // else if(s1.size()!= s2.size()){
        //     return false;
        // }
        // else {
        //     int i = 0;
        //     while(i<s1.size()){
        //         if(s1[i] == s2[i]) i++;
        //         else return false;
        //     }
        // }
        // return true;
    } 
};

第三题:

表达式求值

算法原理:

 题解代码:

class Solution {
public:
    int calculate(string s) {
        //数组模拟
        vector<int> st;
        char op = '+';
        int i =0;
        int n = s.size();
        while(i<n){
            if(s[i] == ' '){
                i++;
            }
            //数字
            else if(s[i]>='0'&&s[i]<='9'){
                int tem = 0;
                while(i<n&&s[i]>='0'&&s[i]<='9'){
                    tem = tem*10+(s[i++]-'0');
                }
                //此时的i指向的是非数字的元素
                if(op == '+') st.push_back(tem);
                if(op == '-') st.push_back(-tem);
                if(op == '*') st.back() *= tem;
                if(op == '/') st.back() /= tem;
            }
            else {
                op = s[i];
                i++;           
            }
        }
        int ret = 0;
        for(auto& e:st){
            ret+=e;
        }
        return ret;
    }
};

 

http://www.dtcms.com/a/109451.html

相关文章:

  • 代码随想录|动态规划|17一和零
  • DAY 35 leetcode 202--哈希表.快乐数
  • QT 非空指针 软件奔溃
  • 检索增强生成(RAG) 优化策略
  • LLM架构解析:长短期记忆网络(LSTM)(第三部分)—— 从基础原理到实践应用的深度探索
  • MyBatis:开源、轻量级的数据持久化框架
  • 游戏引擎学习第201天
  • Muduo网络库实现 [九] - EventLoopThread模块
  • 康谋分享 | 仿真驱动、数据自造:巧用合成数据重构智能座舱
  • 去中心化交易所(DEX)
  • Unity3D开发AI桌面精灵/宠物系列 【三】 语音识别 ASR 技术、语音转文本多平台 - 支持科大讯飞、百度等 C# 开发
  • 【GCC警告报错4】warning: format not a string literal and no format arguments
  • 从扩展黎曼泽塔函数构造物质和时空的结构-13
  • 练习题:120
  • 【Linux学习笔记】开发工具git和gbd和cgbd的介绍和使用
  • PADS 9.5【附破解文件+安装教程】中文激活版下载
  • IP分片攻击实战模拟
  • 蓝桥杯真题——传送阵
  • xsync脚本是一个基于rsync的工具
  • LN2220 2A 高效率升压 DC/DC 电压调整器
  • 前端面试题(二):vue2中v-if和v-show的区别
  • 使用python完成手写数字识别
  • 列表某个字段由多个值组成,使用id匹配展示
  • Angular 项目 PDF 批注插件库在线版 API 示例教程
  • 儿童语义认知功能磁共振成像研究的元分析
  • Python+Playwright自动化测试-1-环境准备与搭建
  • 【爬虫开发】爬虫开发从0到1全知识教程第14篇:scrapy爬虫框架,介绍【附代码文档】
  • [原创](Modern C++)现代C++的关键性概念: 什么是左值?
  • 运维之 Centos7 防火墙(CentOS 7 Firewall for Operations and Maintenance)
  • 17、Swift框架微调实战(2)-QWQ-32B LORA微调cot数据集