1.s.append 只能添加1个元素,应该用s.extend()
2. s.insert(len(s),6)
3.
4. s.insert(len(s),"上山打老虎")
5. s = [ '上', '山', '打', '老', '虎']
6. s = []
ins = input('请输入目标列表:')
for each in ins:
s.append(int(each))
print('列表创建完毕:',s)
s.sort()
s1 = []
print('排序后:',s)
n = int(len(s))
middle = (s)
for each in s:
if not each in s1:
s1.append(each)
print('删重后的列表:',s1)
counts = 0
temp = 0
for each in s1:
temp = s.count(each)
if temp>counts:
counts = temp
maxcount = temp
maxeach = each
print('重复最多元素:',maxeach)
print('重复最多元素的数量:',maxcount)
if maxcount > n // 2:
print("主要元素是:", maxeach)
else:
print("不存在主要元素。") 道阻且长行则将至
第一次听说浅拷贝 小甲鱼如果要是找列表里最后一个下标可不可以用index函数从-1的起始位值开始查找吗,我试了一下结果报错显示列表里不存在查找的值 a=
b=a
b
请教一下,如上所示,如果需要把a列表赋值给其他变量b,直接赋值就行了啊,为什么还要用copy或[:]方法呢? 越来越多知识点了 {:10_257:} 学习的道路慢起来了 我的nusm.sort(reverse=Ture)会报错为什么呀? yechen.kln 发表于 2022-10-25 22:12
我的nusm.sort(reverse=Ture)会报错为什么呀?
我True打成Ture了{:10_250:}{:10_247:}{:10_266:}难怪报错兄弟们有没有一样的…… 学习学习 学习打卡 梦回凡尘几寸欢 发表于 2022-6-24 15:34
小甲鱼如果要是找列表里最后一个下标可不可以用index函数从-1的起始位值开始查找吗,我试了一下结果报错显 ...
nums.index(nums[-1])可以,但最后一个下标不就是len(nums)-1吗。 练习练习练习
python="不给不给"{:10_256:} nums =
nums.sort()
length = len(nums)
half = nums
count = 0
for each in nums:
if each == half:
count += 1
if count > length / 2:
print("存在主要元素是:", half)
else:
print("不存在主要元素!")
half的值为什么会等于2 ? length 等于nums的值等于6那half的值应该是等于3才对? 打卡学习 二、作业
问答题
0. 请问如何不直接使用下标索引值的前提下,将下面列表中的 “黑寡妇
“ 替换为 ”神奇女侠“?
>>> heros = ['蜘蛛侠', '绿巨人', '黑寡妇', '鹰眼', '灭霸', '雷神']
答:heros = '神奇女侠' 。
1. 请问如何将下面列表中的 “蜘蛛侠” 和 “绿巨人” 替换为 “猪猪侠” 和 “女
巨人”?
>>> heros = ['蜘蛛侠', '绿巨人', '神奇女侠', '鹰眼', '灭霸', '雷神']
答:heros = ['猪猪侠','女巨人']
2. 请问以下代码会打印什么内容?
>>> s =
>>> s =
>>> print(s)
答:
3. 请问以下代码会打印什么内容?
>>> s =
>>> s[:] = "FishC"
>>> print(s)
答:['F','i','s','h','C']
4. 请问以下代码会打印什么内容?
>>> s =
>>> s = []
>>> print(s)
答:
5. 请问以下代码会打印什么内容?
>>> s =
>>> t = s
>>> s = 1
>>> print(t)
答:
6. 我们知道,列表的 index() 方法可以找到第一个匹配元素的下标,那么你有没有办法在不改变原列表的情况下,找到最后一个匹配元素的下标
呢?(有两种方法可以实现)
答:
s =
print(len(s[::-1])-1-s[::-1].index(4))
动动手
0. 如果有一个列表,其中占比超过一半的元素称之为主要元素,那么如
何获取一个列表的主要元素呢?
题目给定的列表是:
请根据解题思路进行编程。
解题思路:
根据主要元素的定义,对列表进行排序操作之后,主要元素必然会
出现在列表长度一半之后的一个位置上。所以,我们只需要判断列表中是否有超过一半的元素与中间元素相同即可(如果有,中间元素为主要元素;否则,不存在主要元素)。
1. 其实上面这道题有一个经典的解法,就是使用摩尔投票法(Boyer–Moore majority vote)。摩尔投票法有时候也被称为“多数投票法”,该算法解决的问题是如何在任意多的候选人中(选票无序),找到获得票数最多的那个。
摩尔投票法分为两个阶段:
对抗阶段:分属两个候选人的票数进行两两对抗抵消
• 计数阶段:计算对抗结果中最后留下的候选人票数是否有效
大家不妨可以将摩尔投票法的工作原理想象为诸侯争霸,假设每个
国家都是全民皆兵,并且打起仗来都是以 1 换 1 的形式消耗人口,当一个国家人口总数为 0,那么 Gameover,OK,如果某国人口数量超过所有国家好了,提示到此为止,大家开始专注搞代码吧!
s =
s.sort()
if len(s) % 2 == 0:
a = s
else:
c = len(s) - 1
a = s
b = s.count(a)
if b > int(len(s)/2):
print("主要元素是",a)
else:
print("没有主要元素")
周末多学点,打卡
页:
[1]
2