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

visual studio 做网站搜索引擎广告案例

visual studio 做网站,搜索引擎广告案例,酒店网站建设公司,主播网站建设#include <bits/stdc.h> // 引入常用头文件 using namespace std;stack<int> num; // 存储操作数的栈 stack<char> op; // 存储运算符的栈/* 执行一次运算操作&#xff1a;1. 从num栈弹出两个操作数(n2先弹出&#xff0c;作为右操作数)2. 从op栈弹出运算符…

在这里插入图片描述

#include <bits/stdc++.h>  // 引入常用头文件
using namespace std;stack<int> num;  // 存储操作数的栈
stack<char> op;  // 存储运算符的栈/* 执行一次运算操作:1. 从num栈弹出两个操作数(n2先弹出,作为右操作数)2. 从op栈弹出运算符3. 根据运算符计算结果,将结果压回num栈
*/
void eval()
{// 弹出右操作数(因为栈是后进先出)int n2 = num.top(); num.pop();  // 弹出左操作数int n1 = num.top(); num.pop();  // 弹出当前运算符char oper = op.top(); op.pop();  int res;switch(oper) {  // 根据运算符计算结果case '+': res = n1 + n2; break;case '-': res = n1 - n2; break;case '*': res = n1 * n2; break;case '/': res = n1 / n2; break;}num.push(res);  // 将结果压回操作数栈
}int main()
{string expr;cin >> expr;  // 读取表达式字符串// 定义运算符优先级表,左括号未定义因为需要特殊处理unordered_map<char, int> priority{{'+',1}, {'-',1}, {'*',2}, {'/',2}};for (int i = 0; i < expr.size(); i++) {  // 遍历每个字符char c = expr[i];if (isdigit(c)) {  // 处理数字字符int value = 0;int j = i;// 连续读取完整数字(处理多位数的情形)while (j < expr.size() && isdigit(expr[j])) {value = value * 10 + (expr[j++] - '0');}i = j - 1;  // 更新i到最后一个数字的位置(因为循环会i++)num.push(value);  // 数字压栈/* 模拟过程示例:输入"12+34",当i=0时识别到数字,得到j=2,value=12,将i更新为1,循环继续处理位置2的'+'*/}else if (c == '(') {  // 左括号直接入栈op.push(c);}else if (c == ')') {  // 右括号:计算直到遇到左括号// 不断执行运算,直到栈顶出现左括号while (op.top() != '(') {eval();}op.pop();  // 弹出左括号/* 模拟示例:处理表达式 "(3+5 * 2)" 时,遇到右括号,运算栈中的 '*' 和 '+' 将依次被处理,保留计算结果在num栈中*/}else {  // 处理普通运算符(+-*/)/* 优先级处理:当前运算符优先级 <= 栈顶运算符优先级时,先执行栈顶运算,保证运算顺序正确例如:当前是'+',栈顶是'*'时,先计算乘法*/while (op.size() && op.top() != '(' && priority[c] <= priority[op.top()]) {eval();}op.push(c);  // 当前运算符入栈}}// 处理剩余的所有运算符while (op.size()) {eval();}cout << num.top() << endl;  // 输出最终结果return 0;
}/*
示例表达式处理模拟1:3+5 * 2
1. '3'压入num → num:[3]
2. '+' 入栈 → op:[+]
3. '5'压入num → num:[3,5]
4. '*'优先级高于'+',直接入栈 → op:[+, *]
5. '2'压入num → num:[3,5,2]
6. 表达式结束,处理剩余运算符:- 先处理 '*' → 5 * 2=10 → num:[3,10]- 处理 '+' → 3+10=13 → 输出13示例表达式处理模拟2:7 - (3+2 * 5)
1. '7'压入 → num:[7]
2. '-' 入栈 → op:[-]
3. '(' 入栈 → op:[-, (]
4. '3'入栈 → num:[7,3]
5. '+' 入栈(栈顶是'(',优先不计算) → op:[-, (, +]
6. '2'入栈 → num:[7,3,2]
7. '*'优先级高于'+',入栈 → op:[-, (, +, *]
8. '5'入栈 → num:[7,3,2,5]
9. 遇到')':循环处理运算符到'('- 处理 '*' → 2 * 5=10 → num:[7,3,10]- 处理 '+' → 3+10=13 → num:[7,13]- 弹出 '(' → op:[-]
10.处理剩余运算符 '-' → 7-13= -6 → 输出-6
*/

此篇参考了acwing算法基础课。

http://www.dtcms.com/wzjs/442088.html

相关文章:

  • 网站备案平台查询系统外贸订单一般在哪个平台接
  • 海门网站建设网络营销该如何发展
  • 宝塔默认安装wordpressseo实战密码第三版pdf
  • 浦东网站建设公司网络营销组合策略
  • 三屏合一网站建设关键词怎么写
  • 我有域名怎么做网站深圳网络推广培训机构
  • 写网站建设需求淘宝客推广一天80单
  • golang 做网站怎么查看域名是一级还是二级域名
  • 学院网站建设的目的及定位seo站
  • 公司网站数据分析百度首页排名优化平台
  • 深圳网站关键词优化seo优化网站推广
  • 专门做地图的网站谷歌seo网站推广怎么做优化
  • 网站开发英文合同长沙网站快速排名提升
  • 网站页面设计报价表免费制作个人网站
  • 带做骑传奇私服网站seo免费软件
  • 自己做动漫 哪个网站赚钱在哪买网站链接
  • 校园网站建设网络科技公司
  • 爱站网权重查询江苏搜索引擎优化
  • 设计对网站的重要性网络测试
  • 企业网站优化做法百度云登陆首页
  • 怎么做公司的宣传网站网络推广是做什么的
  • 南宁企业自助建站系统seo推广人员
  • 怎么用别的网站做代理打开谷歌怎样注册自己网站的域名
  • 东莞网站设计制作网站怎样做好销售和客户交流
  • 前端做商城网站需要多久营销比较好的知名公司有哪些
  • 专业做网站有哪些seo技术博客
  • 购买网站服务如何做支出百度明星搜索量排行榜
  • 公司注册资金认缴和实缴的区别整站关键词排名优化
  • 莆田网站建设哪里便宜国际军事新闻最新消息今天
  • 小型企业网络配置实例杭州seo优化