Python 基于python编写一些算法程序等
基于python编写一些算法程序等
by:授客 QQ:1033553122 QQ群:7156436
没特意去研究,只是这对群友在QQ群里(7156436)提出的一些小程序实现、编程题,算法、问题等,本着学习的心态,根据自己的想法帮忙去编写实现而已。
题目1:在一串字符串中找出由连续相同字符组成的最长的子字符串,比如输入aabcd,输出aa,输入ab,输出ab,输入abbbbeee,输出bbb,eee,输入aabbbbee,输出bbb
代码实现如下:
#!/usr/bin/env python
# -*- coding:utf-8 -*-
__author__ =
'shouke'
def
findstr(str_obj):
str_list_final = []
#
存储找到的字符“子串”
second=''
temp_sub_str =
''
str_list =
list(str_obj)
#
把字符串转为列表
for
index,element
in
enumerate(str_list[:]):
#
遍历查找连续的子串,包含只有一个字符的字符串
first = second
second = element
if
first ==
second
and
first !=
'':
#
如果前一个字符串后一个字符不相等
temp_sub_str = temp_sub_str + first
#
拼接字符成“子串”
if
index ==
len(str_list)-1:
#
当字符为最后一个字符时,需要再拼接一次,否则直接退出循环了
temp_sub_str = temp_sub_str + second
str_list_final.append(temp_sub_str)
#
存储最后一个连续的“子串”
else:
#
如果前一个字符串后一个字符不相等
temp_sub_str = temp_sub_str + first
#
依旧要把前一个字符拼接起来(因为它属于连续“子串”中的最后一个字符
str_list_final.append(temp_sub_str)
if
index ==
len(str_list)-1:
str_list_final.append(second)
temp_sub_str =
''
#
置空,开始找下一个连续的“子串”
second =
''
max_lenth_str =
''
#
存储单个长度最大的字符子串
max_lenth_str_list
= []
#
子串可能有多个,可能重复,用list存储,方便后续转为set,去重复
#print(str_list_final)
for
sub_str
in
str_list_final[:]:
first = second
second = sub_str
if
len(first)
<</span>
len(second):
max_lenth_str = second
max_lenth_str_list=[]
#
前一个子串比后一个子串的长度短,把之前存储的全部清空,准备接收刚找到的最长子串
max_lenth_str_list.append(max_lenth_str)
elif
len(first)
==
len(second)
and
len(first)
!=
0:
#
前一个子串和后一个子串相等
max_lenth_str = second
max_lenth_str_list.append(second)
#保持之前存的不变,再拼接一个等长度的子串
elif
len(first)
>
len(second):
#前一个子串比后一个子串的长度长
if
len(first)
>
len(max_lenth_str):
#
需要判断前一个子串是否比上一次存储的最大子串的长度长
max_lenth_str_list=[]
#
前一个比上次的长,清空之前拼接的
max_lenth_str
= first
second = max_lenth_str
print(set(max_lenth_str_list))
#
转set,去掉重复的
if
__name__ ==
'__main__':
findstr("a")
findstr("abcdef")
findstr("abcdeeeeffff")
findstr("aabbcdddeeeffffs")
findstr("a1abbcddddeeeffffs")
运行结果:

更高效的做法:
def
look_substring_for_maxlength(string):
temp_str =
string[0]
result_list
= []
for i in
range(0, len(string)):
if i
temp_str = temp_str + string[i]
else:
temp_str = temp_str + string[i]
if len(temp_str) > 1:
result_list.append(temp_str)
temp_str = ''
result_dic =
{}
for item in
result_list:
result_dic[item] = len(item)
result_list
= sorted(result_dic.items(), key=lambda item:item[1],
reverse=True)
return
result_list[0][0]
print(look_substring_for_maxlength('a1abbcddddeeeffffs'))
题目2:查找整数1到15内的素数
注:素数,只能被1和自己整除的整数
代码实现如下:
#!/usr/bin/env python
# -*- coding:utf-8 -*-
__author__ = 'shouke'
if __name__ == '__main__':
for
num
in
range(1,
16):
flag
=
1
for
fac
in
range(2,
num):
if
num % fac ==
0:
flag
=
0
break
if
flag ==
1:
print('%d是质数'
% num)
运行结果:
题目3:给定一个只包含正整数而且非空的数组,返回该数组中重复次数最多的前N个数字(返回结果按重复次数从多到少降序排列,N不存在取值非法的情况) 用最熟悉的语言或者伪代码实现该需求
代码1:
array = [2,4,2,4,4,5,5,5,5,6,2,6, 8, 8]
array_set = set(array) # 转list为集合
result_dict = {} # 存储数组中对应数字及数字数现次数
for item in array_set:
result_dict[str(item)] = array.count(item)
result_list = sorted(result_dict.items(), key=lambda item:item[1],
reverse=True)
N = 3 # 前3个数
for i in range(0, N):
print(result_list[i][0])
Python 基于python编写一些算法程序等的更多相关文章
- Python 基于Python实现的ssh兼sftp客户端(上)
基于Python实现的ssh兼sftp客户端 by:授客 QQ:1033553122 实现功能 实现ssh客户端兼ftp客户端:实现远程连接,执行linux命令,上传下载文件 测试环境 Win7 ...
- Python 基于Python及zookeeper实现简单分布式任务调度系统设计思路及核心代码实现
基于Python及zookeeper实现简单分布式任务调度系统设计思路及核心代码实现 by:授客 QQ:1033553122 测试环境 功能需求 实现思路 代码实践(关键技术点实现) 代码模块组织 ...
- Python 基于python操纵zookeeper介绍
基于python操纵zookeeper介绍 by:授客 QQ:1033553122 测试环境 Win7 64位 Python 3.3.4 kazoo-2.6.1-py2.py3-none-any.w ...
- Python 基于Python结合pykafka实现kafka生产及消费速率&主题分区偏移实时监控
基于Python结合pykafka实现kafka生产及消费速率&主题分区偏移实时监控 By: 授客 QQ:1033553122 1.测试环境 python 3.4 zookeeper- ...
- Python 基于Python从mysql表读取千万数据实践
基于Python 从mysql表读取千万数据实践 by:授客 QQ:1033553122 场景: 有以下两个表,两者都有一个表字段,名为waybill_no,我们需要从tl_waybill_b ...
- Python 基于Python实现的ssh兼sftp客户端(下)
基于Python实现的ssh兼sftp客户端 by:授客 QQ:1033553122 otherTools.py #!/usr/bin/env/ python # -*- coding:utf-8 ...
- Python基于Python实现批量上传文件或目录到不同的Linux服务器
基于Python实现批量上传文件或目录到不同的Linux服务器 by:授客 QQ:1033553122 实现功能 1 测试环境 1 使用方法 1 1. 编辑配置文件conf/rootpath_fo ...
- Python 基于python+mysql浅谈redis缓存设计与数据库关联数据处理
基于python+mysql浅谈redis缓存设计与数据库关联数据处理 by:授客 QQ:1033553122 测试环境 redis-3.0.7 CentOS 6.5-x86_64 python 3 ...
- Python 基于python操纵redis入门介绍
基于python操纵redis入门介绍 by:授客 QQ:1033553122 测试环境 redis-3.0.7 CentOS 6.5-x86_64 python 3.3.2 基于Python操作R ...
随机推荐
- 你不知道的javascript读书笔记3
概述 这是我看<你不知道的JavaScript(中卷)>中关于类型检查的笔记,供以后开发时参考,相信对其他人也有用. typeof 我们知道js中有七种内置类型:undefined, nu ...
- struts2框架学习笔记1:搭建测试
Servlet是线程不安全的,Struts1是基于Servlet的框架 而Struts2是基于Filter的框架,解决了线程安全问题 因此Struts1和Struts2基本没有关系,只是创造者取名问题 ...
- Failed to acquire lock on file .lock in /tmp/kafka-logs. A Kafka instance in another process or thread is using this directory.
1. 问题现象 启动 kafka 时报错:Failed to acquire lock on file .lock in /tmp/kafka-logs. A Kafka instance in an ...
- scikit-image 图像处理库介绍
今天学习图像处理的时候,无意中看到了scikit 软件包,抱着学习的态度,这里做个记录,方便以后翻阅. 概念:scikit-image 是一种开源的用于图像处理的 Python 包.它包括分割,几何变 ...
- JavaScript 交换数组元素位置的几种方式
前言 交换数组元素位置是开发项目中经常用到的场景,总结下用过的几种方式. 第三方变量 最基础的方式,创建一个变量作为中转. let temp = array[index1]; array[index1 ...
- LeetCode:146_LRU cache | LRU缓存设计 | Hard
题目:LRU cache Design and implement a data structure for Least Recently Used (LRU) cache. It should su ...
- Webpack代理proxy配置,解决本地跨域调试问题,同时允许绑定host域名调试
Webpack代理proxy配置,解决本地跨域调试问题,同时允许绑定host域名调试 会撸码的小马 关注 2018.05.29 17:30* 字数 212 阅读 1488评论 0喜欢 2 接到上一章, ...
- 【sping揭秘】16、@After(finally) 但是这个实在afterturning之前执行
package cn.cutter.start.bean; import org.apache.commons.logging.Log; import org.apache.commons.loggi ...
- JavaScript中的关于this
this在js中是一个特别的关键字,被自动保存在所有函数的作用域中. 为什么要用this this提供一个对象方式隐式传递一个对象的引用,因此可以将api设计的简洁并且容易复用.看下面两段代码的比较: ...
- 归并排序——Merge Sort
基本思想:参考 归并排序是建立在归并操作上的一种有效的排序算法.该算法是采用分治法的一个非常典型的应用.首先考虑下如何将2个有序数列合并.这个非常简单,只要从比较2个数列的第一个数,谁小就先取谁,取了 ...
