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)))

待续...

最新文章

  1. mysql删除重复记录,保存Id最小的一条
  2. [python]获取文件夹下所有文件名
  3. 利用nginx来屏蔽指定的user_agent的访问以及根据user_agent做跳转
  4. viewport和media query
  5. 【BZOJ】1192: [HNOI2006]鬼谷子的钱袋(水题)
  6. 解决:导入第三方jar包后,仍然出现java.lang.NoClassDefFoundError的错误
  7. css之margin && padding讲解
  8. Linux(CentOS)文件操作命令
  9. 屏蔽ubuntu桌面鼠标右键以及Ctrl Alt F*
  10. CentOS 6.5 安装配置VSFTP
  11. 切换view的动画
  12. 10.使用final关键字修饰一个变量时...
  13. sublime在Mac osx下安装z-codeing(即emmet)
  14. Gridview将某列内容和标题隐藏起来
  15. java day02 记录
  16. 从零开始学安全(五)●Vmware虚拟机三种网络模式详解
  17. .htaccess技巧: URL重写(Rewrite)与重定向
  18. 抓包及分析(wireshark&tcpdump)
  19. SHELL (2) —— Shell变量的核心基础知识和实践
  20. html form method 属性不支持put,delete请求方式,以及开启spring mvc的rest的方式

热门文章

  1. 软件工程 - Test-Driven Development (TDD),测试驱动开发
  2. 计算机基础 - 时间戳(timestamp)位数
  3. 笔记-pymysq-exception
  4. 执行脚本,且以脚本名保存log
  5. 如何用一个servlet处理多个请求
  6. c++ 读取、保存单张图片
  7. Python的常用库
  8. Integer a = 200,b=200比较详解
  9. MySQL数据库索引:索引介绍和使用原则
  10. 「ZJOI2013」K大数查询