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

手机网站建设可信赖营销策略ppt模板

手机网站建设可信赖,营销策略ppt模板,海南响应式网页建设找哪家,江西论坛目录 1- 思路栈实现四种情况处理 2- 实现⭐394. 字符串解码——题解思路 3- ACM 实现 原题链接:394. 字符串解码 1- 思路 栈实现四种情况处理 ① 遇到数字,进行倍数相加 、②遇到左括号,压栈之前的元素、③遇到右括号弹出,栈进行…

目录

  • 1- 思路
    • 栈实现+四种情况处理
  • 2- 实现
    • 394. 字符串解码——题解思路
  • 3- ACM 实现

  • 原题链接:394. 字符串解码

1- 思路

栈实现+四种情况处理

  • ① 遇到数字,进行倍数相加 、②遇到左括号,压栈之前的元素、③遇到右括号弹出,栈进行拼接、④否则遇到字母,直接拼接在 res
  • 通过栈,实现先进后出的思想

对于输入 3[a2[c]] 的输入,在读到 3[得到第一个括号 [ 之后才会进行入栈操作,也就是将之前的 3 入栈到一个 multi的栈中

    1. 定义一个 multi 变量用于存储倍数,也就是当前字符串扩大的倍数。
    1. 定义 res变量用于存储临时结果,如果读到的是字符,一直更新 res

读取过程

  • 读取数字:一开始如果读取的都是数字 multi,则对 multi*10 + c - '0'; 的方式
  • 读取字符:如果读取字符,暂存到 res 中,是否压栈取决于遇到的括号
  • 遇到 '[' 括号:如果遇到了左括号,则将 '[' 前状态的 数字 multi 和字符 res 进行压栈,之后重新更新 multires
  • 遇到 ']' 括号:如果遇到了右括号,则需要弹栈,进行处理


2- 实现

394. 字符串解码——题解思路

在这里插入图片描述

class Solution {public String decodeString(String s) {StringBuilder res = new StringBuilder();int multi = 0;// 两个栈Deque<Integer> stack_multi = new ArrayDeque<>();Deque<String> stack_str = new ArrayDeque<>();for(Character c: s.toCharArray()){//  0-9if( c>='0' && c<='9'){multi = multi*10 + c-'0';}else if(c == '['){stack_multi.push(multi);stack_str.push(res.toString());multi = 0;res = new StringBuilder();}else if(c == ']'){StringBuilder tmp = new StringBuilder();int curMulti = stack_multi.pop();for(int i = 0 ; i < curMulti;i++){tmp.append(res);}res = new StringBuilder(stack_str.pop()).append(tmp);}else{res.append(c);}}return res.toString();}
}

3- ACM 实现

public class strDecode {public static String strDecode(String str){// 1. 数据结构int multi = 0;StringBuffer res =  new StringBuffer();// 数字倍数Deque<Integer> stack_multi = new ArrayDeque<>();Deque<String> stack_res = new ArrayDeque<>();// 遍历字符串 strfor(Character c : str.toCharArray()){// 如果是数字 更新倍数if( c>='0' && c<= '9'){multi = multi *10 + c - '0';}else if( c == '['){// 压栈stack_multi.push(multi);stack_res.push(res.toString());// 重置multi = 0;res = new StringBuffer();}else if(c==']'){// 出栈计算int nowMulti = stack_multi.pop();StringBuffer tmp = new StringBuffer();for(int i = 0 ; i < nowMulti;i++){tmp = tmp.append(res);}res = new StringBuffer(stack_res.pop()).append(tmp);}else{res.append(c);}}return res.toString();}public static void main(String[] args) {Scanner sc = new Scanner(System.in);String input = sc.nextLine();System.out.println("结果是"+strDecode(input));}
}

http://www.yayakq.cn/news/787336/

相关文章:

  • 租凭境外服务器做违规网站三维家软件培训班
  • 酒店预订网站建设图片网站建设方案
  • 免费视频素材网站都有哪些网络营销推广方法和手段
  • 备案网站免网泉州网站建设多少钱
  • c 网站开发案例详解湘潭网站建设电话
  • 云邦北京网站建设超级门户博客版wordpress主题
  • 陕西 网站备案企业网络营销策划案例
  • 公司网站建设情况说明书网站外包如何报价
  • 自己做qq代刷网站要钱吗wordpress wampserve
  • 如皋网站定制如何分析一个网站开发语言
  • 个人网站备案容易吗电子商务网站推广的主要方法
  • 建设银行信用卡官方网站网上商城网站开发与建立的意义
  • 网站推广的基本方法是网站域名.xin
  • 网站jquery在线优化网页设计培训好学吗
  • 免费的微信小程序徐州关键字优化公司
  • 网站上传的工具推广系统建站
  • wamp做的网站标签图标中石化两学一做网站
  • 网站登记表网站删除关键词
  • 做网站有什么专业术语合肥网站建设哪家好
  • 高清做网站插图云南网站优化排名
  • 建设网站前需要的市场分析网站改版了
  • 网站做百度推广需要什么材料婚车租赁
  • 上海网站建设制作公司网站建设项目安排计划表
  • 网站建设公司如何签单网站一年续费多少钱
  • 中小企业网站制作流程外贸网站怎么做
  • 生活常识网站源码vps 网站 需要绑定域名吗
  • 攀枝花建设集团网站亚马逊网站联盟
  • 工程造价信息价在什么网站查江镇做包子网站
  • 临海如何制作公司网站框架申请公司
  • 做衣服网站免费网络营销课程