字符串编码/BST插入节点问题

字符串编码

【问题描述】
小明发明了一种给由全大写字母组成的字符串编码的方法。对于每一个大
写字母,小明将它转换成它在 26 个英文字母中序号,即 A → 1, B → 2, … Z →26。
这样一个字符串就能被转化成一个数字序列:
比如 ABCXYZ → 123242526。
现在给定一个转换后的数字序列,小明想还原出原本的字符串。当然这样
的还原有可能存在多个符合条件的字符串。小明希望找出其中字典序最大的字
符串。

【输入格式】
一个数字序列。
【输出格式】
一个只包含大写字母的字符串,代表答案
【样例输入】
123242526
【样例输出】
LCXYZ

【评测用例规模与约定】
对于 20% 的评测用例,输入的长度不超过 20。
对于所有评测用例,输入的长度不超过 200000。

public class ZiFubma {
     
	public static void main(String[] args) {
     
		Scanner sc=new Scanner(System.in);
		String s=sc.next();
		StringBuilder res=new StringBuilder();
		for(int i=0;i<s.length();i++) {
     
			int k=s.charAt(i)-'0';
			if(k<=2) {
     
				int t=k*10+s.charAt(i+1)-'0';
				if(t<=26) {
     
					res.append((char)('A'+t-1));
					i++;
					continue;
				}
				
			}
			res.append((char)('A'+k-1));
		}
		System.out.println(res.toString());
	}
}

BST插入节点问题

【问题描述】
给定一棵包含 N 个节点的二叉树,节点编号是 1 ∼ N。其中 i 号节点具有
权值 Wi,并且这些节点的权值恰好形成了一棵排序二叉树 (BST)。
现在给定一个节点编号 K,小明想知道,在这 N 个权值以外,有多少个整
数 X (即 X 不等于任何 Wi ) 满足:给编号为 K 的节点增加一个权值为 X 的子
节点,仍可以得到一棵 BST。
例如在下图中,括号外的数字表示编号、括号内的数字表示权值。即编号
1 ∼ 4 的节点权值依次是 0、10、20、30。
如果 K = 1,那么答案为 0。因为 1 号节点已经有左右子节点,不能再增
加子节点了。
如果 K = 2,那么答案为无穷多。因为任何一个负数都可以作为 2 的左子
节点。
如果 K = 3,那么答案为 9。因为 X = 11, 12, · · · , 19 都可以作为 3 的左子
节点。
【输入格式】
第一行包含 2 个整数 N 和 K。
以下 N 行每行包含 2 个整数,其中第 i 行是编号为 i 的节点的父节点编号
Pi 和权值 Wi 。注意 Pi = 0 表示 i 是根节点。
输入保证是一棵 BST。
【输出格式】
一个整数代表答案。如果答案是无穷多,输出 -1。
【样例输入】
4 3
0 10
1 0
1 20
3 30
【样例输出】
9
【评测用例规模与约定】
对于 60% 的评测用例,1 ≤ K ≤ N ≤ 100,0 ≤ Wi ≤ 200,且 Wi 各不相同。
对于所有评测用例,1 ≤ K ≤ N ≤ 10000,0 ≤ Wi ≤ 100000000,且 Wi 各不相同。

public class BST {
     

	public static void main(String[] args) {
     
		Scanner input = new Scanner(System.in);
		int n = input.nextInt();
		int k = input.nextInt();
		int a[] = new int[100100];
		int b[] = new int[100100];
		int vis[] = new int[100010];
		for(int i = 1; i <= n; i++) {
     
			a[i] = input.nextInt();
			b[i] = input.nextInt();
			vis[i] = a[i];
		}
		int cnt = 0;
		int ans = 0;
		for(int i = 1; i <= n; i++) {
     
			if(vis[i]==k) {
     
				cnt++;
				ans = b[i];
			}
		}
		if(cnt==2) System.out.print(0);
		else if(cnt==1) {
     
			ans = Math.abs(ans-b[k]);
			System.out.print(ans-1);
		}else System.out.print(-1);
	}

}

你可能感兴趣的:(蓝桥杯Java)