鱼C论坛

 找回密码
 立即注册
查看: 3004|回复: 12

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

[复制链接]
发表于 2021-4-17 00:45:20 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
【问题描述】

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

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

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

【输出形式】

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


【样例输入】

[4,3,2,3,2,4,True]

【样例输出】
[3, 2, 4, True]


list_a = eval(input())
list_b=[str(i) for i in list_a]
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)

我的代码输出的相对位置不对,而且列表中带有字符时会报错
最佳答案
2021-4-17 00:54:10
list1 = [1, 2, 3, 4, 4, 3, 2, 1, 1, 2, 23, 1, 23, 13, 23, 445, 8]

list2 = []
for each in range(len(list1)-1, -1, -1):
    if list1[each] not in list2:
        list2.append(list1[each])
list2.reverse()
print(list2)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-4-17 00:54:10 | 显示全部楼层    本楼为最佳答案   
list1 = [1, 2, 3, 4, 4, 3, 2, 1, 1, 2, 23, 1, 23, 13, 23, 445, 8]

list2 = []
for each in range(len(list1)-1, -1, -1):
    if list1[each] not in list2:
        list2.append(list1[each])
list2.reverse()
print(list2)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2021-4-17 02:48:51 | 显示全部楼层
本帖最后由 kogawananari 于 2021-4-17 02:53 编辑


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

list1 = [1, 2, 3, 4, 4, 3, 2, 1, 1, 2, 23, 1, 23, 13, 23, 445, 8]

d=dict.fromkeys(reversed(list1))

print(list(reversed(d.keys())))
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-4-17 02:50:50 | 显示全部楼层

只可惜d[True]和d[1]一样的,这道题用不了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-4-17 03:40:03 | 显示全部楼层
data = [4,3,1,2,3,2,4,True]
data2 = [(i,type(i)) for i in data]

data3 = []
for i in data2[::-1]:
    if i not in data3:
        data3.append(i)
res = [x for x,y in data3[::-1]]
print(res)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2021-4-17 10:04:14 | 显示全部楼层

本来想用集合做的,结果
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-4-17 10:51:47 | 显示全部楼层
本帖最后由 阿奇_o 于 2021-4-17 15:46 编辑
柿子饼同学 发表于 2021-4-17 10:04
本来想用集合做的,结果


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

ls_r = ls[::-1]
#print(ls_r)
si = [ls_r.index(i) for i in set(ls)]
si.sort()  #别忘了这一步了。。
#print(si)
result = [ls_r[i] for i in si][::-1]
print(result)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-4-17 11:00:42 | 显示全部楼层
报错是,因为你 先用了 str(i) , 然后 再用 map(int, list_c)  相当于 逐个用 int(i) , 于是,
当 原值 为 True 时,被 str() 转为了 'True' 是字符串,且 不是 纯数字字符串,所以 再 int(i) ,自然会报错。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

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

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

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

ls = [1, 2, 3, 4, 4, 3, 2, 1, 1, 2, 23, 1, 23, 13, 23, 445, 8]

要是没有限制条件,可以用集合的话, print(list(set(ls))) 一行就结束了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-4-17 15:02:00 | 显示全部楼层
kogawananari 发表于 2021-4-17 02:50
只可惜d[True]和d[1]一样的,这道题用不了

没注意啊, 这题目 1 和 True 竟然还要分开???

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-4-17 15:55:30 | 显示全部楼层
Daniel_Zhang 发表于 2021-4-17 14:42
肯定不能用集合,你看题目要求

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

什么不能用集合,集合只是没顺序而已,
我set去重后得到唯一值,再根据这些唯一值,查逆序的列表中该值在哪(下标多少),再sort()一下就地排序,
因为是在逆序列表里找,ls_r.index(i) 就能找到 在原序列中最后一个出现的值。
最后我再倒过来,就可以了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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


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

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

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

一开始我也想用集合,但是得颠来倒去的,有一点点麻烦
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-4-17 19:13:31 | 显示全部楼层
Daniel_Zhang 发表于 2021-4-17 16:55
我之前说错了,没太仔细看你的

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

嗯,这里 的确不是很合适,你是对的,倒来倒去是有点绕
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-16 02:37

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表