字符串解码 栈与递归

24 篇文章 0 订阅

方法一:利用两个栈


public class ZiFuChuanJieMa {

	public static void main(String[] args) {
		Solution6 a = new Solution6();
		
		
		System.out.println(a.decodeString("3[ab]"));

	}

}
class Solution6 {
    public String decodeString(String s) {
    	char[] a = s.toCharArray();
    	Stack<Integer> i1 = new Stack<Integer>();
    	Stack<String> s1 = new Stack<String>();
    	int num = 0;
    	for(int i = 0;i < s.length();i++) {
    		if(Character.isDigit(a[i])) {
    			num  = num * 10 + Integer.parseInt(String.valueOf(a[i])); 
    		}else if(a[i] == '[') { 			
    			i1.push(num);
    			s1.push(String.valueOf(a[i]));
    			num = 0;	
    		}else if(Character.isLetter(a[i])) {
    			s1.push(String.valueOf(a[i]));
    		}else {
    			int b = i1.pop();
    			String x = new String();  			
    			while(!s1.peek().equals("[")) {
    				x = s1.pop() + x;			
    			}
    			s1.pop();
    			String c = new String();
    			
    			while(b > 0) {
    				c += x;
    				b--;
    			}
    			s1.push(c);
    			
    		}
    	}
    	String d = new String();
    	while(!s1.isEmpty()) {
    		d = s1.pop() + d;
    	}
    	return d;
    }
}

方法二 : 递归

package com.leetcode;

import java.util.Arrays;
import java.util.Stack;

public class ZiFuChuanJieMa {

	public static void main(String[] args) {
		Solution6 a = new Solution6();
		
		
		System.out.println(a.decodeString("3[ab]"));

	}

}

class Solution6 {
	public String decodeString(String s) {
		return dfs(s, 0)[0];
	}

	private String[] dfs(String s, int i) {
		StringBuilder res = new StringBuilder();
		int multi = 0;
		while (i < s.length()) {
			if (s.charAt(i) >= '0' && s.charAt(i) <= '9')
				multi = multi * 10 + Integer.parseInt(String.valueOf(s.charAt(i)));
			else if (s.charAt(i) == '[') {
				String[] tmp = dfs(s, i + 1);
				i = Integer.parseInt(tmp[0]);//一次走完括号 i直接变为 ] 的下标
				while (multi > 0) {
					res.append(tmp[1]);
					multi--;
				}
			} else if (s.charAt(i) == ']')
				return new String[] { String.valueOf(i), res.toString() };//[]内部的
			else//是字母的情况
				res.append(String.valueOf(s.charAt(i)));//加入字符串 a ab
			i++;
		}
		return new String[] { res.toString() };//while走完后的
	}

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: cjson字符串转树结构是指将一个符合cjson格式的字符串转换成一个树形结构的数据。首先,我们需要解析cjson字符串,将其转换成对应的数据对象。cjson字符串通常以大括号{}或者中括号[]为起始和结束,并且使用逗号分隔不同的数据项。 要实现cjson字符串到树结构的转换,可以采用递归的方式。首先,解析字符串的起始字符,如果是大括号表示一个对象,如果是中括号表示一个数组。然后,可以循环递归地解析对象或者数组中的每一项数据,并将其转换成对应的树节点。 对于对象,我们可以将每个键值对转换成一个树节点,其中键作为节点的名称,值作为节点的值。对于数组,我们可以将每个元素转换成一个树节点,并将它们作为子节点添加到一个数组节点中。 在递归解析过程中,可以通过或者递归来保存解析过程中的临时数据。当解析完成后,树结构就建立完成了,并且可以进行进一步的操作,例如遍历、查找等。 总结来说,cjson字符串转树结构的过程主要包括解析cjson字符串,创建对应的树节点,并将节点连接成树形结构。通过递归解析每个数据项,我们可以逐步地构建出完整的树结构。这个转换过程可以实现对cjson数据的分层处理和数据结构化,方便进行后续的操作和处理。 ### 回答2: 使用cjson库将cjson字符串转换为树结构的步骤如下: 1. 首先导入cjson库,可以使用`require "cjson"`语句进行导入。 2. 定义一个函数,例如`jsonToTree`,该函数接收一个cjson字符串作为参数。 3. 在函数内部,使用`cjson.decode()`将cjson字符串解码为Lua中的table对象。例如,可以使用`local jsonTable = cjson.decode(jsonString)`将cjson字符串解码为table对象。 4. 创建一个树结构的数据结构,可以使用table来表示。例如,可以使用一个table来表示树的节点,每个节点包含数据和子节点的列表。可以定义一个`Node`函数来创建节点,例如`local function Node(data) return {data=data, children={}} end`。 5. 遍历解码后的jsonTable,将每个节点添加到树中。可以使用递归的方式进行遍历,首先创建根节点,然后递归遍历每个节点的子节点。 6. 最后,返回根节点,完成cjson字符串转换为树结构的过程。可以使用`return rootNode`语句将根节点返回。 下面是一个示例代码: ```lua require "cjson" local function Node(data) return { data=data, children={} } end local function addChildren(parentNode, children) for _, childData in ipairs(children) do local childNode = Node(childData) table.insert(parentNode.children, childNode) end end local function jsonToTree(jsonString) local jsonTable = cjson.decode(jsonString) local rootNode = Node(nil) addChildren(rootNode, jsonTable.children) return rootNode end ``` 通过调用`jsonToTree`函数并传入一个cjson字符串,即可将该字符串转换为树结构。 ### 回答3: cjson是一个用于解析和生成JSON格式字符串的库,它可以将JSON字符串转换为树形结构进行操作。在使用cjson将字符串转为树结构时,首先需要创建一个根节点,然后通过遍历字符串中的键值对来构建树结构。 具体的步骤如下: 1. 导入cjson库,并将JSON字符串作为输入参数传递给cjson的解析函数。 2. 解析函数将会返回一个cjson对象,我们将其作为根节点。 3. 遍历解析后的根节点,可以使用cjson提供的函数来获取节点的子节点、键值对等信息。 4. 如果节点是一个数组,可以通过循环遍历数组中的元素,并将每个元素提取出来作为子节点添加到当前节点中。 5. 如果节点是一个对象,可以使用递归的方式,将对象中的键值对逐个添加到当前节点中,并将值作为子节点。 6. 完成后,可以通过在根节点上调用cjson的生成函数,将树结构转换为JSON字符串。 需要注意的是,在使用cjson转换树结构时,要确保JSON字符串的格式是正确的,否则解析函数可能会报错。另外,对于大型的JSON字符串,解析和构建树结构可能会消耗较多的内存和时间,需要在使用时注意性能的问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值