向一个空栈中依次存入正整数
假设入栈元素N(1<=N<=2^31-1)
按顺序依次为Nx
… N4
、N3
、N2
、N1
,
当元素入栈时,如果N1=N2+...Ny
(y
的范围[2,x]
,1 <= x <= 1000
)
则 N1 到 Ny 全部元素出栈,重新入栈新元素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
,所有两个六全部出栈存入12
最终栈中只剩一个元素12