计算堆栈中的剩余数字

更多关于刷题的内容欢迎订阅我的专栏华为刷题笔记

该专栏题目包含两部分:

100 分值部分题目

200 分值部分题目

所有题目都会陆续更新,订阅防丢失

题目描述:

向一个空栈中依次存入正整数,

假设入栈元素 n ( 1 < = n < = 2 3 1 − 1 ) n(1<=n<=2^31-1) n(1<=n<=231−1)按顺序依次为 n x . . . n 4 、 n 3 、 n 2 、 n 1 nx...n4、n3、n2、n1 nx...n4、n3、n2、n1,

每当元素入栈时,如果 n 1 = n 2 + . . . + n y n1=n2+...+ny n1=n2+...+ny ( y y y的范围 [ 2 , x ] [2,x] [2,x], 1 < = x < = 1000 1<=x<=1000 1<=x<=1000 ),则 n 1 n y n1~ny n1 ny 全部元素出栈,重新入栈新元素 m ( m = 2 ∗ n 1 ) m(m=2*n1) m(m=2∗n1)。

如:依次向栈存入6、1、2、3,

当存入6、1、2时,栈底至栈顶依次为[6、1、2];

当存入3时,3=2+1,3、2、1全部出栈,重新入栈元素6(6=2*3),此时栈中有元素6;因为6=6,所以两个6全部出栈,存入12,最终栈中只剩一个元素12。

输入描述:

使用单个空格隔开的正整数的字符串,如"5 6 7 8", 左边的数字先入栈,

输入的正整数个数为 x , 1 < = x < = 1000 x,1<=x<=1000 x,1<=x<=1000。

输出描述:

最终栈中存留的元素值,元素值使用空格隔开,如"8 7 6 5", 栈顶数字在左边。

示例1

输入:

复制代码
5 10 20 50 85 1

输出:

复制代码
1 170

说明:

5+10+20+50=85, 输入85时,5、10、20、50、85全部出栈,入栈170,最终依次出栈的数字为1和170。

示例2

输入:

复制代码
6 7 8 13 9

输出:

复制代码
9 13 8 7 6

说明:

示例3

输入:

复制代码
1 2 5 7 9 1 2 2

输出:

复制代码
4 1 9 14 1

题解

使用 list 模拟栈的操作

源码 Java

java 复制代码
public class StackEnter {

	static List<Integer> list = new ArrayList<>();

	static Input input;
	static {
		input = new Input("5 10 20 50 85 1");
		input = new Input("6 7 8 13 9");
	}

	public static void main(String[] args) {
		String[] split = input.nextLine().split(" ");
		for (int i = 0; i < split.length; i++) {
			push(Integer.parseInt(split[i]));
		}
		Integer pop = pop();
		StringBuilder builder = new StringBuilder();
		while (pop != null) {
			builder.append(pop).append(" ");
			pop = pop();
		}
		System.out.println(builder.toString().trim());
	}

	public static void push(Integer value){
		int sum = 0;
		for (int i = list.size() - 1; i >= 0; i--) {
			sum += list.get(i);
			if (sum == value) {
				break;
			} else if (sum > value) {
				break;
			}
		}
		if (sum == value) {
			while (sum > 0) {
				Integer pop = pop();
				sum -= pop;
			}
			value = value * 2;
		}
		list.add(value);
	}

	public static Integer pop(){
		if (list.isEmpty()){
			return null;
		}
		return list.remove(list.size()-1);
	}

}
相关推荐
Coder码匠32 分钟前
Dockerfile 优化实践:从 400MB 到 80MB
java·spring boot
漫随流水36 分钟前
leetcode算法(111.二叉树的最小深度)
数据结构·算法·leetcode·二叉树
reddingtons8 小时前
【游戏宣发】PS “生成式扩展”流,30秒无损适配全渠道KV
游戏·设计模式·新媒体运营·prompt·aigc·教育电商·游戏美术
李慕婉学姐8 小时前
【开题答辩过程】以《基于JAVA的校园即时配送系统的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·开发语言·数据库
じ☆冷颜〃8 小时前
黎曼几何驱动的算法与系统设计:理论、实践与跨领域应用
笔记·python·深度学习·网络协议·算法·机器学习
数据大魔方8 小时前
【期货量化实战】日内动量策略:顺势而为的短线交易法(Python源码)
开发语言·数据库·python·mysql·算法·github·程序员创富
POLITE38 小时前
Leetcode 23. 合并 K 个升序链表 (Day 12)
算法·leetcode·链表
楚来客9 小时前
AI基础概念之八:Transformer算法通俗解析
人工智能·算法·transformer
Echo_NGC22379 小时前
【神经视频编解码NVC】传统神经视频编解码完全指南:从零读懂 AI 视频压缩的基石
人工智能·深度学习·算法·机器学习·视频编解码
会员果汁9 小时前
leetcode-动态规划-买卖股票
算法·leetcode·动态规划