文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

学习python的第十七天(二分法,有名

2023-01-31 00:50

关注

一.二分法

二分法个人理解是一种算法的方式在一个有序的序列,区中间值,把中间值与想要的值进行对比从而一次一次的减少搜索范围举例

#给与一个列表1-100,
num_list = [num fornum in range(1,101)]
#给予一个num让你在列表中寻找他
mid_num_index = int(len(num_list)/2)
mid_num = num_list[mid_num_index]
if len(num_list)==1:
    if num_list[0]==num:
        print('找到了')
    else:
        print('没找到')
else:
    if mid_num>num:
        num_list = num_list[:mid_num_index]
    elif mid_num<num:
        num_list = num_list[mid_num_index:]
    else:
        print('找到了')

二.有名函数

就是有函数名的函数

三.匿名函数

没有函数名的函数,而且只能使用一次就会被回收掉

定义方式

lambda 输入内容:对于输入内容进行处理后的输出内容
如
#输入为x,y输出他们的和
lambda x,y:x+y

匿名函数的调用

(lambda 输入内容:对于输入内容进行处理后的输出内容)(输入内容)
#例如
x_y_sum = (lambda x,y:x+y)(1,2)

四.内置函数

1.重要

1.bytes()解码字符

res = bytes('你好', encoding='utf8')
#           内容              解码方式
#效果等同于
res = '你好'.encode('utf8')

2.chr()/ord()

chr()参考ASCII码表将数字转成对应字符;ord()将字符转换成对应的数字。

print(ord('a'))  #97
#打印为a的ascll码
print(chr(97))  #a
#ascll码为97的是a

3..enumerate()

带有索引的迭代。

l = ['a', 'b', 'c']
for i in enumerate(l):   #生成索引加内容的迭代器,其为索引加索引对应内容组成的一个集合
    print(i)
'''
(0, 'a')
(1, 'b')
(2, 'c')
'''
l = [['a', 'b'], 'c']
for i in enumerate(l):  #生成索引加内容的迭代器,其为索引加索引对应内容组成的一个集合
    print(i)
​```
(0, ['a', 'b'])
(1, 'c')
​```

4.divmod()

print(divmod(10, 3))
#(3, 1)
divmod(x, y)
#(x//y,x%y)

5.eval()

把字符串两端的''去掉里面内容是什么就是什么
lis = '[1,2,3]'
lis_eval = eval(lis)
print(lis_eval)
#[1, 2, 3]

6.hash()

2.了解

1.abs()

绝对值

print(abs(-13)
#13      

print(all([1, 2, 3, 0]))
print(all([1]))
print(all([]))
False
True
True

3.any()

可迭代对象中有一元素为真,则为真。

如果可迭代对象内元素是空的,返回False。

print(any([1, 2, 3, 0]))
print(any([]))
print(any([1]))
True
False
True

4.bin()/oct()/hex()

二进制、八进制、十六进制转换。

print(bin(17))
print(oct(17))
print(hex(17))
'''
0b10001
0o21
0x11
'''

5.dir()

列举出所有time的功能

import time
print(dir(time))
'''
['_STRUCT_TM_ITEMS', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'altzone', 'asctime', 'clock', 'ctime', 'daylight', 'get_clock_info', 'gmtime', 'localtime', 'mktime', 'monotonic', 'perf_counter', 'process_time', 'sleep', 'strftime', 'strptime', 'struct_time', 'time', 'timezone', 'tzname', 'tzset']
'''

6.frozenset()

不可变集合

s = frozenset(任意数据类型)
将其中的任意数据类型变成集合的形式,且该集合不能修改

7.globals()/loacals()

查看全局名字;查看局部名字。

# print(globals())
def func():
    a = 1
#     print(globals())
    print(locals())


func()
#{'a': 1}   

8.pow()

print(pow(3, 2, 3))  # (3**2)%3
#0

9.round()

四舍五入

print(round(3.5))
#4

10.slice()

lis = ['a', 'b', 'c']
s = slice(0, 1, 2)  #有点像切片
print(lis[s])  # print(lis[0:1:2])

11.sum()

求和

12._import_

通过字符串导入模块。

m = __import__('time')
print(m.time())

#1556607502.334777
阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯