删除列表中的重复值,但相对位置不变<新人求助>
【问题描述】输入一个列表,删除其中的重复值,再输出。
要求:假设列表中存在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)
我的代码输出的相对位置不对,而且列表中带有字符时会报错 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:53 编辑
Daniel_Zhang 发表于 2021-4-17 00:54
我有一个骚操作你看怎么样(我是python3.9)
list1 =
d=dict.fromkeys(reversed(list1))
print(list(reversed(d.keys()))) Daniel_Zhang 发表于 2021-4-17 00:54
只可惜d和d一样的,这道题用不了 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)
Daniel_Zhang 发表于 2021-4-17 00:54
本来想用集合做的,结果{:10_266:} 本帖最后由 阿奇_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)
报错是,因为你 先用了 str(i) , 然后 再用 map(int, list_c)相当于 逐个用 int(i) , 于是,
当 原值 为 True 时,被 str() 转为了 'True' 是字符串,且 不是 纯数字字符串,所以 再 int(i) ,自然会报错。
阿奇_o 发表于 2021-4-17 10:51
去重肯定首选集合呀,再充分利用列表推导式,和切片可倒转列表,
3, 4行代码就搞定了,
肯定不能用集合,你看题目要求
试试这个,你看看你的可以通过不?
ls =
要是没有限制条件,可以用集合的话, print(list(set(ls))) 一行就结束了{:10_250:} kogawananari 发表于 2021-4-17 02:50
只可惜d和d一样的,这道题用不了
没注意啊, 这题目 1 和 True 竟然还要分开???{:10_250:}
Daniel_Zhang 发表于 2021-4-17 14:42
肯定不能用集合,你看题目要求
试试这个,你看看你的可以通过不?
什么不能用集合,集合只是没顺序而已,
我set去重后得到唯一值,再根据这些唯一值,查逆序的列表中该值在哪(下标多少),再sort()一下就地排序,
因为是在逆序列表里找,ls_r.index(i) 就能找到 在原序列中最后一个出现的值。
最后我再倒过来,就可以了。 阿奇_o 发表于 2021-4-17 15:55
什么不能用集合,集合只是没顺序而已,
我set去重后得到唯一值,再根据这些唯一值,查逆序的列表中该值 ...
我之前说错了,没太仔细看你的
但是首选也不应该是集合吧,集合还得倒来倒去的{:10_285:}
我个人觉得还是 F5 的大佬的比较好理解
一开始我也想用集合,但是得颠来倒去的,有一点点麻烦 Daniel_Zhang 发表于 2021-4-17 16:55
我之前说错了,没太仔细看你的
但是首选也不应该是集合吧,集合还得倒来倒去的
嗯,这里 的确不是很合适,你是对的,倒来倒去是有点绕
页:
[1]