核心内容摘要
无尽画廊:在光影交错中,重新定义动漫的禁断魅力
(新卷,100分)- 堆栈中的剩余数字Java JS Python题目描述向一个空栈中依次存入正整数假设入栈元素 n(1n2^31-
按顺序依次为 nx…n
n
n
n1, 每当元素入栈时如果 n1n2…ny(y 的范围[2,x] 1x
则 n1~ny 全部元素出栈重新入栈新元素 m(m2*n
。
如依次向栈存入
6、
1、
3, 当存入
6、
2 时栈底至栈顶依次为[
6、
2]当存入 3时 321
3、
1 全部出栈重新入栈元素 6(62*
此时栈中有元素 6因为 66所以两个 6 全部出栈存入 12最终栈中只剩一个元素 12。
输入描述使用单个空格隔开的正整数的字符串如”5 6 7 8″ 左边的数字先入栈输入的正整数个数为 x 1x1000。
输出描述最终栈中存留的元素值元素值使用空格隔开如”8 7 6 5″ 栈顶数字在左边。
6 1 2 3用例输入5 10 20 50 85 1输出1 170说明510205085 输入 85 时
5、
10、
20、
85 全部出栈入栈 170最终依次出栈的数字为 1 和 170。
输入6 7 8 13 9输出9 13 8 7 6说明无输入1 2 5 7 9 1 2 2输出4 1 9 14 1说明无题目解析本题较为简单的解题思路是每当有元素num将要入栈前都尝试num去依次减去栈顶到栈底方向的栈中元素注意这只是遍历栈的过程而不是弹栈过程如果有出现num 0则将遍历过栈元素全部弹栈并压入num * 2。
如果没有出现num 0则栈不做变动只压栈num但是需要注意的是对于情况1而言我们需要注意题目描述中的这句话每当元素入栈时如果 n1n2…ny(y 的范围[2,x] 1x
则 n1~ny 全部元素出栈重新入栈新元素 m(m2*n
那么压栈 num * 2 是否也算新元素入栈呢是否需要继续检查等价栈元素呢我理解是需要的即这个压栈num * 2 的过程是一个需要递归的过程。
Java算法源码import java.util.Arrays; import java.util.LinkedList; import java.util.Scanner; import java.util.StringJoiner; public class Main { public static void main(String[] args) { Scanner sc new Scanner(System.in); int[] nums Arrays.stream(sc.nextLine().split( )).mapToInt(Integer::parseInt).toArray(); System.out.println(getResult(nums)); } public static String getResult(int[] nums) { LinkedListInteger stack new LinkedList(); stack.add(nums[0]); for (int i 1; i nums.length; i) { push(nums[i], stack); } StringJoiner sj new StringJoiner( ); while (stack.size()