通过输入的位置重新排列可变大小的列表

问题描述

我需要一些关于如何使用输入的位置顺序(例如 ["A","B","C","D"])重新排列名称列表(例如 [3,1,4,2])的建议。

问题是名称列表的大小从 14 是可变的,位置也是可变的,基于输入。它们的长度是一样的,所以当有3个名字时,位置就有3个值。

在基本的非重排名称列表["A","D"]中,值的位置:A is 1,B is 2等。

示例:未重新排列的名称是 ["Mat","Bara","Tom"] 所以 Mat 是 1,Bara 是 2,Tom 是 3

示例:新位置应为 [3,2]

示例:重新排列的列表将是 ["Tom","Mat","Bara"]

到目前为止,我已经尝试过 names[positions[i]] 之类的方法以及其他一些方法,但都没有成功。

这是目前为止非常简单的代码

num = 0
pos_list = []
name_list = []

num = int(input("how many names:"))
for i in range(num):
    name = input("input name:")
    name_list.append(name)
    pos = int(input("enter the positions that the names should be arranged to:"))
    pos_list.append(pos)

# first name entered is 1,the second name entered is 2 so on...
# Now they have to be rearranged by the inputted positions

任何建议表示赞赏:)

解决方法

使用list comprehension

names_list = ["A","B","C","D"]
pos_list = [3,1,4,2]
print([names_list[i-1] for i in pos_list])
# ['C','A','D','B']

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...