无论哪种方式都可以,我该怎么做?我需要一个修改实际列表本身的方法。我试过这样做:
// Reverses this list.
public void reverse() {
for (int i = 0, j = size - 1; i < size && j >= 0; i++, j--)
set(i, get(j));
}
......但我失败了。它的中途重新开始,我只是在吮吸。输出最终是:
List: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24]
Reversed: [24, 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24]
如何避免在数字到达中间时重复这个问题?感谢。
答案 0 :(得分:1)
爵士
我设法做到了这一点,你可以添加自己的逻辑来减少我使用过的for循环。但我希望它在某种程度上有所帮助。
for(int i=0;i<list.size()/2;i++) {
int val = list.removeLast();
System.out.println("i:" + i + " val " + val);
reverseList.add(val);
}
for(int i=list.size()/2;i<list.size();i++) {
int val = list.removeLast();
System.out.println("i:" + i + " val " + val);
reverseList.add(val);
}
for(int i=list.size()/4;i<list.size();i++) {
int val = list.removeLast();
System.out.println("i:" + i + " val " + val);
reverseList.add(val);
}
for(int i=list.size()/6;i<list.size();i++) {
int val = list.removeLast();
System.out.println("i:" + i + " val " + val);
reverseList.add(val);
}
for(int i=list.size()/8;i<list.size();i++) {
int val = list.removeLast();
System.out.println("i:" + i + " val " + val);
reverseList.add(val);
}
for(int i=list.size()/10;i<list.size();i++) {
int val = list.removeLast();
System.out.println("i:" + i + " val " + val);
reverseList.add(val);
}
for(int i=list.size()/12;i<list.size();i++) {
int val = list.removeLast();
System.out.println("i:" + i + " val " + val);
reverseList.add(val);
}
答案 1 :(得分:1)
当您浏览列表时,您将使用结尾的值覆盖值的前半部分,从而丢失这些早期值。当你到达列表的后半部分时,上半部分的原始值不再存在!
尝试使用交换逻辑(在每次迭代时交换两个元素)并且仅在列表的一半处进行:
public void reverse() {
int half = size / 2;
for (int i = 0; i < half; i++) {
int j = size - 1 - i; // position of matching element at the other end
T item = get(i); // T is the type of data stored in the list
set(i, get(j));
set(j, item);
}
}
请注意,您无需将中间元素与自身交换。