列表理解内的递增计数器

问题描述

我写了一个函数,该函数将列出列表中所有不连续的整数及其索引,它可以工作,但是我想知道是否有可能将其变成单线。我的原始代码如下:

def all_non_consecutive(arr):
  result = []
  i = 1
  for num in arr[1:]:
      if arr[i-1] != num -1:
          result.append({'i': arr.index(num),'n':  num})
      i += 1
  return result

我正在尝试的是这个

def all_non_consecutive(arr):
  result = []
  i= 1
  return [{'i': arr.index(num),'n':  num} for num in arr[1:] if num - 1 != arr[i-1]]

但是正如您所看到的,没有增加i的功能,因此代码无法正常工作。有没有办法使列表理解在变量外部递增?

解决方法

您可以在range(1,len(arr))上进行迭代,而不是直接在列表上进行迭代。

void main() async {
  var x = [MyClass(),HisClass(),YourClass()];

  var list = x.map(Something
      .builder); // Instance of 'Something<MyClass>',Instance of 'Something<HisClass>',Instance of 'Something<YourClass>'

  print(list);
}

class Foo {}

class MyClass extends Foo {}

class HisClass extends Foo {}

class YourClass extends Foo {}

class Something<T extends Foo> {
  Something();

  static Something<Foo> builder(Foo item) {
    switch (item.runtimeType) {
      case (MyClass):
        return Something<MyClass>();
      case (HisClass):
        return Something<HisClass>();
      case (YourClass):
        return Something<YourClass>();
    }

    return Something<Foo>();
  }
}

列表理解。

def all_non_consecutive1(arr):
  result = []
  i = 1
  for i in range(1,len(arr)):
      if arr[i-1] != arr[i] - 1:
          result.append({'i': i,'n':  arr[i]})
  return result

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...