我对以这样一种方式迭代列表很感兴趣,即我可以从任何位置开始并通过上升到末尾来迭代整个列表,然后循环回到开头并迭代到起始位置.
假设我想对保证有 4 个元素的数组执行此操作: char array[4] = {'a', 'b', 'c', 'd'}
我在构造一个 for 循环时遇到困难,这样我就可以从“a”开始,然后循环 abcd,或者从“b”开始,然后循环 bcda,或者从 d 开始,然后循环 dabc,等等。
我认为 for 循环的初始部分类似于 i = startingPosition。
我认为 for 循环的递增部分类似于 i = (i+1) % 4。这样,从索引 2 开始,例如,将上升到 3,然后是 0,然后是 1,等等.
中间的“终止”条件应该是什么?
for(i = startingPosition; ???; i = (i+1)%4)
谢谢!
最佳答案
对循环控制使用正常迭代,然后调整索引模大小:
for (i = 0; i < size; i++) {
int index = (i + startingPosition) % size;
// Do stuff with array[index]
}
关于c - C 中的 "Circular"for 循环,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19601002/