将列表中的单个或多个顺序项移动到任何位置

问题描述 投票:1回答:1

我需要在列表中移动单个或多个顺序的项目,连续的意思是如果项目多于一个,则其列表索引中没有空格,这是我尝试过的...

def move(x, tomove, idx):
    move_start = tomove[0]
    move_end = tomove[-1] + 1
    if idx == len(x) or idx == len(x) - 1:
        return x[:move_start] + x[move_end:] + x[move_start:move_end]
    elif idx == 0:
        return x[move_start:move_end] + x[:move_start] + x[move_end:]
    else:
        pass

# move to start
print (move([0,1,2,3,4,5,6],
            [2],
            0))
# expected output [2,0,1,3,4,5,6]

# move to end
print (move([0,1,2,3,4,5,6],
            [2],
            6))
# expected output [0,1,3,4,5,6,2]

# move forward single
print (move([0,1,2,3,4,5,6],
            [2],
            3))
# expected output [0,1,3,2,4,5,6]

# move backward single
print (move([0,1,2,3,4,5,6],
            [2],
            1))
# expected output [0,2,1,3,4,5,6]

# move forward multiple
print (move([0,1,2,3,4,5,6],
            [2,3],
            5))
# expected output [0,1,4,5,2,3,6]

# move backward multiple
print (move([0,1,2,3,4,5,6],
            [4,5],
            2))
# expected output [0,1,4,5,2,3,6]
python python-3.x list
1个回答
1
投票

由于您没有提及任何有关验证的内容,例如如果给定的元素序列不存在于原始列表中,主列表和给定列表的排序等。我没有考虑任何验证。

在进入代码之前,让我们看看如何破解解决方案。首先,您需要确定给定列表在主列表中的现有位置。

move_list_pos = lis.index(move_list[0])

现在,检查给定列表是向前还是向后移动。

  • 如果需要向后移动,则它们在主列表中没有变化直到新位置,插入给定列表,然后继续主列表(给定列表除外)。
  • 如果需要继续前进,则主列表应在此处除了主列表中的给定列表,直到新位置,再添加给定列表,请从新位置开始继续执行主列表。

解决方案代码:

def move(lis,move_list,pos):
    move_list_pos = lis.index(move_list[0])
    if pos<move_list_pos:
        return lis[:pos]+move_list+lis[pos:move_list_pos]+lis[move_list_pos+len(move_list):]
    else:
        return lis[:move_list_pos]+lis[move_list_pos+len(move_list):pos+1]+move_list+lis[pos+1:]
© www.soinside.com 2019 - 2024. All rights reserved.