python怎么实现数组元素两两相加
发表于:2025-01-16 作者:千家信息网编辑
千家信息网最后更新 2025年01月16日,这篇"python怎么实现数组元素两两相加"文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这
千家信息网最后更新 2025年01月16日python怎么实现数组元素两两相加
这篇"python怎么实现数组元素两两相加"文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇"python怎么实现数组元素两两相加"文章吧。
数组元素两两相加
count = 0c2 = []for i in range(len(c)): if count == 0: mm = c[i] #print(mm) #print(count) if count == 1: print(c[i]) value = c[i] + mm c2 = np.append(c2,value) count = 0 mm = 0 value = 0 continue count = count + 1
c是原数组,我们设置一个count,当count=0时我们不操作,count=1时我们把当前元素与前一元素相加。
count=0其实相当于奇数,count=1相当于偶数
求数组中两两相加等于20的组合(Python实现)
题目
求数组中两两相加等于20的组合。
例:给定一个数组[1, 7, 17, 2, 6, 3, 14],这个数组中满足条件的有两对:17+3=20, 6+14=20。
解析
分为两个步骤:
先采用堆排序或快速排序对数组进行排序,时间复杂度为O(nlogn)。
然后对排序的数组分别从前到后和从后到前进行遍历, 时间复杂度为O(n)。
假设从前到后遍历的下标为begin,从后到前遍历的下标为end。
当arr[begin] + arr[end] < 20时,满足条件的数一定在[begin+1, end]之间;
当arr[begin] + arr[end] > 20时,满足条件的数一定在[begin, end-1]之间;
当arr[begin] + arr[end] = 20时,找到一组符合条件的数,剩下的组合一定在[begin-1, end-1]之间。
整个算法的时间复杂度为O(nlogn)。
Python实现
# -*- coding:utf-8 -*-def quick_sort(arr, left, right): """快速排序""" if left >= right: return low = left high = right p = arr[left] while left < right: while left < right and arr[right] >= p: right -= 1 arr[left] = arr[right] while left < right and arr[left] <= p: left += 1 arr[right] = arr[left] arr[left] = p quick_sort(arr, low, left-1) quick_sort(arr, left+1, high)def find_sum(arr, sum): """寻找数组中相加等于sum的组合""" quick_sort(arr, 0, len(arr) - 1) begin, end = 0, len(arr) - 1 while begin < end: if arr[begin] + arr[end] < sum: begin += 1 elif arr[begin] + arr[end] > sum: end -= 1 else: print('%s %s' % (arr[begin], arr[end])) begin += 1 end -= 1if __name__ == '__main__': arr = [1, 7, 17, 2, 6, 3, 14] find_sum(arr, 20)
以上就是关于"python怎么实现数组元素两两相加"这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注行业资讯频道。
数组
元素
内容
排序
条件
组合
复杂
之间
复杂度
时间
下标
文章
步骤
知识
篇文章
两个
价值
偶数
大部分
奇数
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
北竺网络技术服务
香港耀磊服务器靠谱吗
网络安全动画英语
数据库前台开发
实况足球服务器
软件工程与数据库专业考研
网络安全单元注册
机关网络安全报告
安阳学习软件开发
厚德普惠网络技术上市
select数据库查询
国庆节期间加强公司网络安全管理
日本免费服务器在线播放
网络安全工作部署落实情况
苏州大学数据库期末考试
有什么好方法学数据库
网络技术主管工作职责
网络安全心得体会初中
青岛憬淮网络技术有限公司
串口服务器ttl信号怎么测
部队手机网络安全警示词
金融游戏软件开发
徐汇区上门软件开发厂家代理价格
服务器管理网卡的用处
数据库单值约束有什么用
榆林市易德软件开发有限公司
数据库面试常见题
网络安全法纪心得体会2
数据库安全控制的应用
判断软件开发好坏的指标