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

使用堆栈(Stack)

集合类型(Collection)下篇_xml collection-CSDN博客

以上是堆栈的简单介绍,下方是堆栈的使用

题目:给定一个逆波兰表达式(后缀表达式)的字符串数组tokens,其中每个元素是一个操作数(数字)或者操作符(+-*/)。使用Stack<double>来计算表达式的值。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace 逆波兰表达式
{internal class Program{static void Main(string[] args){string[] tokens = { "3", "7", "+", "6", "*" };Console.WriteLine(EvaluatePostfix(tokens));}static double EvaluatePostfix(string[]tokens){Stack<double> stack = new Stack<double>();foreach (string token in tokens){if(double.TryParse(token,out double num)){stack.Push(num);}else{double operand2 = stack.Pop();double operand1 = stack.Pop();switch (token){case "+":stack.Push(operand1 + operand2);break;case "-":stack.Push(operand1 - operand2);break;case "*":stack.Push(operand1 * operand2);break;case "/":stack.Push(operand1 / operand2);break;}}}return stack.Pop();}}
}

http://www.lryc.cn/news/499151.html

相关文章:

  • 雨晨 2610(2)0.2510 Windows 11 24H2 Iot 企业版 LTSC 2024 极简 2in1
  • HDD 2025年技术趋势深度分析报告
  • 算法-字符串-22.括号生成
  • Free-RTOS实现LED闪烁
  • NLP论文速读(斯坦福大学)|使用Tree将语法隐藏到Transformer语言模型中正则化
  • 再谈多重签名与 MPC
  • CTF学习24.11.19[音频隐写]
  • vue的watch是否可以取消? 怎么取消?
  • 23、枚举
  • Java基本概念
  • C++学习——如何析构派生类
  • SpringCloud与Dubbo的区别
  • C# 设计模式--建造者模式 (Builder Pattern)
  • leetcode 23. 合并 K 个升序链表
  • 【Redis】深入解析Redis缓存机制:全面掌握缓存更新、穿透、雪崩与击穿的终极指南
  • SQL语法——DQL查询
  • 云计算.运维.面试题
  • 基于vue和vite的计算器
  • 《OpenCV:视觉世界的魔法钥匙》
  • 部署kafka并通过python操作
  • 【JAVA】Java高级:数据库监控与调优:SQL调优与执行计划的分析
  • 【单片机开发】MCU三种启动方式(Boot选择)[主Flash/系统存储器(BootLoader)/嵌入式SRAM]
  • 跨库移植 SQL
  • (软件测试文档大全)测试计划,测试报告,测试方案,压力测试报告,性能测试,等保测评,安全扫描测试,日常运维检查测试,功能测试等全下载
  • Vue前端开发-路由跳转及带参数跳转
  • 服务器上安装 Node.js
  • 在阿里云/Linux环境搭建Gitblit服务
  • MicroBlaze软核开发(二):GPIO
  • threejs相机辅助对象cameraHelper
  • Luma 视频生成 API 对接说明