字符串题汇总(python3)
2024-10-08 15:25:07
1、最小编辑距离
假设有两个字符串s1和s2,计算通过增添、删除、替换三种操作后,从s1转变为s2所需要的操作次数。
#coding=utf-8
class Solution:
def editDist(self,s1,s2):
m,n=len(s1)+1,len(s2)+1
matrix = [[0]*n for i in range(m)]
matrix[0] = [i for i in range(n)]
for i in range(m):
matrix[i][0] = i for i in range(1,m):
for j in range(1,n):
if s1[i-1] == s2[j-1]:
temp = 0
else:
temp = 1
matrix[i][j] = min(matrix[i][j-1]+1,matrix[i-1][j]+1,matrix[i-1][j-1]+temp) return matrix[m-1][n-1]
2、替换空格
请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。
# -*- coding:utf-8 -*-
class Solution:
def replaceSpace(self, s):
temp = []
for i in s:
if i != ' ':
temp.append(i)
else:
temp.append('%20')
return ''.join(temp)
3、字符串的排列
输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。
这也是个神题目,思路没怎么看懂。
# -*- coding:utf-8 -*-
class Solution:
def Permutation(self, ss):
lens = len(ss)
if lens == 0:
return []
if lens == 1:
return [ss]
sl = []
for i in range(lens):
for j in self.Permutation(ss[:i]+ss[i+1:]):
sl.append(ss[i]+j)
return sorted(list(set(sl)))
待续...
最新文章
- mysql删除重复记录,保存Id最小的一条
- [python]获取文件夹下所有文件名
- 利用nginx来屏蔽指定的user_agent的访问以及根据user_agent做跳转
- viewport和media query
- 【BZOJ】1192: [HNOI2006]鬼谷子的钱袋(水题)
- 解决:导入第三方jar包后,仍然出现java.lang.NoClassDefFoundError的错误
- css之margin &;&; padding讲解
- Linux(CentOS)文件操作命令
- 屏蔽ubuntu桌面鼠标右键以及Ctrl Alt F*
- CentOS 6.5 安装配置VSFTP
- 切换view的动画
- 10.使用final关键字修饰一个变量时...
- sublime在Mac osx下安装z-codeing(即emmet)
- Gridview将某列内容和标题隐藏起来
- java day02 记录
- 从零开始学安全(五)●Vmware虚拟机三种网络模式详解
- .htaccess技巧: URL重写(Rewrite)与重定向
- 抓包及分析(wireshark&;tcpdump)
- SHELL (2) —— Shell变量的核心基础知识和实践
- html form method 属性不支持put,delete请求方式,以及开启spring mvc的rest的方式