加载中...

洛谷P1030

P1030 [NOIP2001 普及组] 求先序排列

思路:

  1. 由后序遍历序列求出根
  2. 由中序遍历序列求出左右子树
  3. 递归上述1 2 直到中序/后续遍历序列为空
public class P1030 {// 已AC

	public static void main(String[] args) {
		Scanner scanner = new Scanner(System.in);
		String s1 = scanner.nextLine();// 中序序列
		String s2 = scanner.nextLine();// 后序序列
		dfs(s1, s2);
	}

	/**
	 * @param s1 先序遍历序列
	 * @param s2 后序遍历序列
	 */
	private static void dfs(String s1, String s2) {
		if (s1.length() > 0) {
			char root = s2.charAt(s2.length() - 1);
			int rootIndex = s1.indexOf(root);
			System.out.print(root);
			dfs(s1.substring(0, rootIndex), s2.substring(0, rootIndex));
			dfs(s1.substring(rootIndex + 1), s2.substring(rootIndex, s2.length() - 1));
		}

	}
}

image-20230304121234430
此题所涉及的工具 str.substring(0, 10); 需要注意,截取的字符中不含有下标为10的字符,字符截取范围为(0,9)

posted @ 2023-03-04 12:14  ChuenSan  阅读(26)  评论(0编辑  收藏  举报