python在for循环中不能删除正在循环的列表

版权声明:作者:weizu_cool https://blog.csdn.net/qq_26460841/article/details/87618070

如,本意是删除列表中的33元素,但是由于两个元素位置相近,在找到第一个33的时候,删除后,元素就自动向前补齐,此时i已经后移,所以在使用remove删除相邻元素的时候会:删除一个元素,漏掉一个元素:

下面用C++模拟:

#include<iostream>
using namespace std;
struct list{
	int a[7];
	int length;
};
int main(void){
	struct list l;
	l.a[0] = 11;l.a[1] = 22;l.a[2] = 33;l.a[3] = 33;l.a[4] = 44;l.a[5] = 55;l.a[6]=66;
	
	l.length = 7;
	for(int i=0;i<l.length;i++){
		if(l.a[i]==33){
			for(int j=i;j<l.length;j++){
				l.a[j] = l.a[j+1];
			}
			l.length -= 1;
		}
	}
	
	//print
	for(int i=0;i<l.length;i++){
		cout<<l.a[i]<<endl;   //结果:11 22 33 44 55 66 
	}
	
	return 0;
}

 在C++中,我们不会出这个问题,因为C++中不是python中的自动填充,需要我们自己处理接下来的元素,在C++中,应对这种情况可以采用在删除后i--,后退一个位置,再继续判断。

但是在Python中是自动填充,而且不是C++中的for循环中方便得到每个此时遍历元素的下标,所以这种方式在Python中是不太合适的。这里我们可以考虑再定义一个列表,用遍历一个列表,删除另一个列表(即:不操作正在遍历的列表)解决。

C++中的下标回退,这里给出部分截图:

猜你喜欢

转载自blog.csdn.net/qq_26460841/article/details/87618070