我必须检查堆栈中哪两个值等于100的总和并打印出indecis和数字。我已经使用数组使这成为可能但我无法使用堆栈工作。请帮我。我写了以下内容直到现在,并没有给我正确的输出。
import java.util.Stack;
public class 2 {
public static void main(String[] args) {
int x = 100;
Stack stack=new Stack();
Stack tempStack=new Stack();
stack.push(new Integer(20));
stack.push(new Integer(53));
stack.push(new Integer(41));
stack.push(new Integer(38));
stack.push(new Integer(28));
stack.push(new Integer(47));
stack.push(new Integer(70));
stack.push(new Integer(30));
stack.push(new Integer(80));
stack.push(new Integer(400));
stack.push(new Integer(3));
stack.push(new Integer(20));
tempStack = (Stack) stack.clone();
for (int i=0; i<stack.size(); i++) {
tempStack = (Stack) stack.clone();
int value = (Integer) stack.pop();
if (!stack.isEmpty()) {
for (int k=0; k<tempStack.size(); k++) {
int tmp = (Integer) tempStack.pop();
if ((value + tmp) == x) {
System.out.println("Indices " + i + " & " + k + " with values "
+ value + " & " + tmp);
}
}
}
}
}
}
以下是基于阵列的解决方案:
public class 1 {
public static void main(String[] args) {
int x = 100;
int [] array = {20,3,400,80,30,70,20,47,28,38,41,53,20};
for (int i=0; i<array.length; i++){
int temp1 = array[i];
for (int k=1; k<array.length; k++) {
int temp2 = array[k];
if ((temp1+temp2)==x)
System.out.println("Indices " + i + " & " + k + " with values "
+ temp1 + " & " + temp2);
}
}
}
}
答案 0 :(得分:4)
由于Stack
是Collection
,它实现了the toArray(T[])
method,因此您可以使用它将堆栈转换为数组并使用工作数组解决方案。
但是,您将遇到阵列没有自动装箱的问题。自动装箱会自动在原始类型和对象之间进行转换,这意味着,例如,您可以直接向int
添加Stack
值,而无需创建Integer
个对象,因为编译器会为您执行此操作:
Stack<Integer> stack = new Stack<Integer>();
stack.push(20);
stack.push(53);
但是,编译器不会在int[]
和Integer[]
之间进行转换,因此您必须这样做:
Integer[] array = stack.toArray(new Integer[stack.size()]);
使用Integer[]
将是一件苦差事。
所以最简单的事情就是:
int[] array = new int[stack.size()];
for (int i = 0; i < array.length; i++) {
array[i] = stack.get(i);
}
创建一次数组比重复克隆和清空Stack更有效。
(虽然如果这是一个家庭作业问题,旨在教你如何使用堆栈,这可能不是最好的方法!)
答案 1 :(得分:1)
巡回逻辑几乎没有变化,不要在循环中取stack.size()
,在每次循环迭代时递减,所以你只迭代半循环
int stackSize = stack.size();
for (int i=0; i<stackSize; i++) {
tempStack = (Stack) stack.clone();
int value = (Integer) stack.pop();
if (!stack.isEmpty()) {
int tempSize = tempStack.size();
for (int k=0; k<tempSize; k++) {
int tmp = (Integer) tempStack.pop();
if ((value + tmp) == x) {
System.out.println("Indices " + i + " & " + k + " with values "
+ value + " & " + tmp);
}
}
}
}
答案 2 :(得分:1)
第二个堆栈的索引可能不正确,因为当您在循环内克隆初始堆栈时,每次迭代它都会更小。
即
stack = {25,50}
stack.clone => {25,50}
stack.pop => 25
stack.clone => {50}
thus, if 50+50== 100 the indicies found would be i=1, k=0 instead of 1,1...
答案 3 :(得分:1)
您的代码似乎给出了正确的Numbers组合,但它无法提供正确的Index组合。
这是因为您正在调用pop
函数,该函数从堆栈中删除项目,从而将其大小减小1.因此,您获得的索引是与该时刻的堆栈大小相比的索引。
相反,我建议使用peek()
或get(int index)
函数来读取值。我已经使用get(index)
更新了您的示例,而没有克隆堆栈...看看......
import java.util.Stack;
public class Class2 {
public static void main(String[] args) {
int x = 100;
Stack stack=new Stack();
Stack tempStack=new Stack();
stack.push(new Integer(20));
stack.push(new Integer(53));
stack.push(new Integer(41));
stack.push(new Integer(38));
stack.push(new Integer(28));
stack.push(new Integer(47));
stack.push(new Integer(70));
stack.push(new Integer(30));
stack.push(new Integer(80));
stack.push(new Integer(400));
stack.push(new Integer(3));
stack.push(new Integer(20));
// tempStack = (Stack) stack.clone();
for (int i=0; i<stack.size(); i++) {
// tempStack = (Stack) stack.clone();
int value = (Integer) stack.get(i);
if (!stack.isEmpty()) {
for (int k=i+1; k<stack.size()-1; k++) {
int tmp = (Integer) stack.get(k);
System.out.println("Value"+value+" tmp "+tmp+"Stack size"+stack.size());
if ((value + tmp) == x) {
System.out.println("Indices " + i + " & " + k + " with values "
+ value + " & " + tmp);
}
}
}
}
}
}
答案 4 :(得分:1)
这是一个不自然的堆栈使用(想要知道你如何在'面向堆栈的'Forth中做到这一点?你会使用一个数组。),所以你正在努力奋斗。也就是说,在实现这些堆栈运算符后,只需使用您的数组解决方案:
DEPTH,返回堆栈中元素的数量。
PICK,它将索引处的元素返回到堆栈中。
如果您被允许使用它们,java.util.Stack将继承:.size()
和.elementAt()
答案 5 :(得分:1)
您的堆栈基础解决方案的问题就在这一行。 int value =(Integer)stack.pop(); 一旦弹出第一个元素,它将从堆栈中消失