当前位置: 首页 > news >正文

手机端网站开发要注意什么网站建设哪家公司好

手机端网站开发要注意什么,网站建设哪家公司好,网站建设销售岗位职责,wordpress标题优化数据结构与算法 —— 常用算法模版 二分查找素数筛最大公约数与最小公倍数 二分查找 人间若有天堂,大马士革必在其中;天堂若在天空,大马士革必与之齐名。 —— 阿拉伯谚语 算法若有排序,二分查找必在其中;排序若要使用…

数据结构与算法 —— 常用算法模版

  • 二分查找
  • 素数筛
  • 最大公约数与最小公倍数

二分查找

人间若有天堂,大马士革必在其中;天堂若在天空,大马士革必与之齐名。 —— 阿拉伯谚语
算法若有排序,二分查找必在其中;排序若要使用,二分查找必与之齐名。 —— 木子李

(1)初始化左右指针
left 指向数组的起始位置(索引0)。
right 指向数组的末尾位置(索引len(arr) - 1)。
(2)循环条件
while left <= right:只要左指针不大于右指针,就继续搜索。这意味着搜索区间是有效的。
计算中间位置:
mid = left + (right - left) // 2:这是计算中间位置的标准方式。使用 (right - left) // 2 而不是 (right + left) // 2 是为了防止当 left 和 right 都很大时,它们的和可能超过整数类型的最大值,导致溢出。通过先减去再除以2,可以安全地计算出中间索引。
(3)检查中间元素
如果 arr[mid] == target,则找到了目标元素,返回其索引 mid。
如果 arr[mid] < target,说明目标元素在 mid 的右侧,因此将 left 更新为 mid + 1,缩小搜索范围到右半部分。
如果 arr[mid] > target,说明目标元素在 mid 的左侧,因此将 right 更新为 mid - 1,缩小搜索范围到左半部分。
(4)返回结果
如果循环结束还没有找到目标元素,则返回 -1,表示目标元素不在数组中。
(5)注意事项
确保输入的数组 arr 是有序的,因为二分查找依赖于数组的有序性。
mid 的计算方式可以防止整数溢出,这是在处理大数据集时的一个重要考虑因素。
返回值 -1 表示未找到目标元素,可根据需要自定义这个返回值。

# 排序是为了更快查找,不为了更快查找没必要排序。
def binary_search(arr, target):left, right = 0, len(arr) - 1while left <= right:# 防止(left + right)直接相加导致的整数溢出,这里mid有两种写法mid = left + (right - left) // 2  # 检查mid位置的元素if arr[mid] == target:return mid  # 找到目标,返回索引elif arr[mid] < target:left = mid + 1  # 目标在mid右侧else:right = mid - 1  # 目标在mid左侧return -1  # 未找到目标,返回-1
array = [1,2,3,4,5]
for left in range(0, len(array)):for right in range(left, len(array)):if (right - left) % 2 == 0:print("奇数个元素:(",end="")else:print("偶数个元素:(",end="")for x in range(left, right + 1):if x < right:print(f"{x},",end="")if x == right:print(f"{x}",end="")print(")")# 关于mid的两种写法print(f"mid = (right + left) // 2 = ", (right + left) // 2)print(f"mid = (right + left + 1) // 2 = ", (right + left + 1) // 2)print("\n")

奇数个元素:(0)
(right + left) // 2 = 0
(right + left + 1) // 2 = 0

偶数个元素:(0,1)
(right + left) // 2 = 0
(right + left + 1) // 2 = 1

奇数个元素:(0,1,2)
(right + left) // 2 = 1
(right + left + 1) // 2 = 1
可以看到在偶数个元素时,(right + left) // 2 = mid下标偏左,(right + left + 1) // 2 = mid下标偏右,奇数个元素时都是对的

参考文章与视频链接
[1]《大马士革刀传奇,一把宝刀,两座刀锋下的城市》

素数筛

def sieve_of_eratosthenes(n):# 创建一个布尔数组,初始化为 True,表示所有数都是素数is_prime = [True] * (n + 1)p = 2while (p * p <= n):# 如果 is_prime[p] 没有被改变,那么它是一个素数if is_prime[p]:# 更新 p 的所有倍数为 False,表示它们不是素数for i in range(p * p, n + 1, p):is_prime[i] = Falsep += 1# 收集所有的素数prime_numbers = [p for p in range(2, n + 1) if is_prime[p]]return prime_numbers# 示例使用
n = 30
primes = sieve_of_eratosthenes(n)
print(f"小于或等于 {n} 的素数有: {primes}")

最大公约数与最小公倍数

# 最大公约数
"""
a = 40, b = 104
算法过程
a       b   remain
40  % 104 =   40 
104 %  40 =   24
40  %  24 =   16
24  %  16 =   8
16  %   8 =   0
8   %   0 =   不执行,结束
return a
"""
def gcd(a: int, b: int):while b != 0:remain = a % ba = bb = remainreturn a# 最小公倍数
def lcm(a: int, b: int):return int((a * b) / gcd(a, b))if __name__ == '__main__':print(gcd(400, 20))  # 20print(lcm(400, 20))  # 400
http://www.yayakq.cn/news/239618/

相关文章:

  • 江苏泰州建设局网站东莞seo优化关键词排名
  • 网站几几年做的怎么查企业网站建设知识
  • 智慧养老网站开发网站建设制作 优帮云
  • 广元商城网站开发网站建设开发收费
  • 儿童教育自适应网站模板网站运营问题
  • 河北省建设厅网站登陆设置网站开发周期定义
  • 湛江城市建设培训中心网站wordpress安装详细
  • 深圳网站建设 网站制作 网站设计【迅美】旧版上海网站建设宣传
  • 购物网站宣传方案服装设计是冷门专业吗
  • 燃烧学课程网站建设网上注册营业执照
  • 苏州市建设培训网站安全员C类查询wordpress获取本文地址和标题
  • 网站被恶意点击怎么办深圳企业网站哪家强
  • 杭州pc网站建设方案建筑人才网官网档案查询
  • 响水网站建设公司敬请期待的图片
  • 帝国cms能做手机网站吗企业网站源码排行
  • 宿州网站开发建设wordpress页面伪静态nginx
  • 先用ps后用dw做网站wordpress wow.js
  • 套别人的网站模板吗如何制作网站导航
  • 网站建设报告内容nodejs+php+wordpress
  • 做网站申请什么商标网站开发项目计划书
  • 梁山网站建设电话常州模板建站定制网站
  • 网站建设与管理行业发展情况大型网站建设洛阳网站制作
  • 本地手机网站建设网站开发需要哪些知识和工具
  • 网站排名关键词用个人的信息备案网站吗
  • 公司的网站建设费会计分录文联网站建设方案
  • 通化市住房和城乡建设局网站wordpress评论邮箱
  • 郑州高新区做网站开发的公司python做网站有什么弊端
  • 家装效果图网站加油站顶棚网架价多少钱一平
  • 网站建设平台源码提供做虚拟币网站需要什么手续
  • 定制企业网站有哪些手机制作音乐的软件app