akcw 发表于 2021-4-17 00:45:20

删除列表中的重复值,但相对位置不变<新人求助>

【问题描述】

输入一个列表,删除其中的重复值,再输出。

要求:假设列表中存在k个值为a的元素,删除前k-1个元素,保留最后一个。 不同元素在列表中的相对位置不应被改变。
【输入形式】

[元素1, 元素2, ... , 元素n]

【输出形式】

[元素1,元素2, ... , 元素k]


【样例输入】



【样例输出】



list_a = eval(input())
list_b=
string = ''.join(list_b)
r = ','.join(x for i, x in enumerate(string)if string.index(x) == i)
list_c = r.split(",")
list_d=list(map(int, list_c))
print(list_d)

我的代码输出的相对位置不对,而且列表中带有字符时会报错

Daniel_Zhang 发表于 2021-4-17 00:54:10

list1 =

list2 = []
for each in range(len(list1)-1, -1, -1):
    if list1 not in list2:
      list2.append(list1)
list2.reverse()
print(list2)

kogawananari 发表于 2021-4-17 02:48:51

本帖最后由 kogawananari 于 2021-4-17 02:53 编辑

Daniel_Zhang 发表于 2021-4-17 00:54


我有一个骚操作你看怎么样(我是python3.9)

list1 =

d=dict.fromkeys(reversed(list1))

print(list(reversed(d.keys())))

kogawananari 发表于 2021-4-17 02:50:50

Daniel_Zhang 发表于 2021-4-17 00:54


只可惜d和d一样的,这道题用不了

qq1151985918 发表于 2021-4-17 03:40:03

data =
data2 = [(i,type(i)) for i in data]

data3 = []
for i in data2[::-1]:
    if i not in data3:
      data3.append(i)
res = ]
print(res)

柿子饼同学 发表于 2021-4-17 10:04:14

Daniel_Zhang 发表于 2021-4-17 00:54


本来想用集合做的,结果{:10_266:}

阿奇_o 发表于 2021-4-17 10:51:47

本帖最后由 阿奇_o 于 2021-4-17 15:46 编辑

柿子饼同学 发表于 2021-4-17 10:04
本来想用集合做的,结果

去重肯定首选集合呀,再充分利用列表推导式,和切片可倒转列表,
3, 4行代码就搞定了,
ls =

ls_r = ls[::-1]
#print(ls_r)
si =
si.sort()#别忘了这一步了。。
#print(si)
result = for i in si][::-1]
print(result)

阿奇_o 发表于 2021-4-17 11:00:42

报错是,因为你 先用了 str(i) , 然后 再用 map(int, list_c)相当于 逐个用 int(i) , 于是,
当 原值 为 True 时,被 str() 转为了 'True' 是字符串,且 不是 纯数字字符串,所以 再 int(i) ,自然会报错。

Daniel_Zhang 发表于 2021-4-17 14:42:03

阿奇_o 发表于 2021-4-17 10:51
去重肯定首选集合呀,再充分利用列表推导式,和切片可倒转列表,
3, 4行代码就搞定了,

肯定不能用集合,你看题目要求

试试这个,你看看你的可以通过不?

ls =

要是没有限制条件,可以用集合的话, print(list(set(ls))) 一行就结束了{:10_250:}

Daniel_Zhang 发表于 2021-4-17 15:02:00

kogawananari 发表于 2021-4-17 02:50
只可惜d和d一样的,这道题用不了

没注意啊, 这题目 1 和 True 竟然还要分开???{:10_250:}

阿奇_o 发表于 2021-4-17 15:55:30

Daniel_Zhang 发表于 2021-4-17 14:42
肯定不能用集合,你看题目要求

试试这个,你看看你的可以通过不?


什么不能用集合,集合只是没顺序而已,
我set去重后得到唯一值,再根据这些唯一值,查逆序的列表中该值在哪(下标多少),再sort()一下就地排序,
因为是在逆序列表里找,ls_r.index(i) 就能找到 在原序列中最后一个出现的值。
最后我再倒过来,就可以了。

Daniel_Zhang 发表于 2021-4-17 16:55:15

阿奇_o 发表于 2021-4-17 15:55
什么不能用集合,集合只是没顺序而已,
我set去重后得到唯一值,再根据这些唯一值,查逆序的列表中该值 ...

我之前说错了,没太仔细看你的

但是首选也不应该是集合吧,集合还得倒来倒去的{:10_285:}

我个人觉得还是 F5 的大佬的比较好理解

一开始我也想用集合,但是得颠来倒去的,有一点点麻烦

阿奇_o 发表于 2021-4-17 19:13:31

Daniel_Zhang 发表于 2021-4-17 16:55
我之前说错了,没太仔细看你的

但是首选也不应该是集合吧,集合还得倒来倒去的


嗯,这里 的确不是很合适,你是对的,倒来倒去是有点绕
页: [1]
查看完整版本: 删除列表中的重复值,但相对位置不变<新人求助>