- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章python3实现字符串的全排列的方法(无重复字符)由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
最近在学一些基础的算法,发现我的数学功底太差劲了,特别是大学的这一部分,概率论、线性代数、高数等等,这些大学学的我是忘得一干二净(我当时学的时候也不见得真的懂),导致现在学习算法,非常的吃力。唉!不说了,补习中。。.
抛出问题 。
求任意一个字符串的全排列组合,例如a='123',输出 123,132,213,231,312,321。(暂时假定字符串没有重复) 。
解决方案 。
目前有两种解决的方法 。
方法一:
1
2
3
4
5
6
7
8
9
10
11
12
|
def
str_sort(s
=
''):
if
len
(s) <
=
1
:
return
[s]
str_list
=
[]
for
i
in
range
(
len
(s)):
for
j
in
str_sort(s[
0
:i]
+
s[i
+
1
:]):
str_list.append(s[i]
+
j)
return
str_list
str_list
=
str_sort(
'abc'
)
print
(
len
(str_list), str_list)
|
这种理解起来非常好理解,就是循环遍历每个字符,让每个字符打头,然后继续递归遍历后边的字符 。
方法二:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
#字符串任意两个位置字符交换
def
str_replace(
str
, x, y):
if
x
=
=
y:
return
str
x_val
=
str
[x:x
+
1
]
y_val
=
str
[y:y
+
1
]
if
x < y:
str
=
str
[
0
:x]
+
y_val
+
str
[x
+
1
:y]
+
x_val
+
str
[y
+
1
:
len
(
str
)]
else
:
str
=
str
[
0
:y]
+
x_val
+
str
[y
+
1
:x]
+
y_val
+
str
[x
+
1
:
len
(
str
)]
return
str
#递归求结果
def
str_sort(
str
,x):
if
x
=
=
len
(
str
):
#当x为字符串的最大长度时返回当前字符交换的结果
global
str_list
str_list.append(
str
)
return
for
i
in
range
(x,
len
(
str
)):
str
=
str_replace(
str
,i,x)
#递归遍历第i个字符,
str_sort(
str
,x
+
1
)
str
=
str_replace(
str
,x,i)
#恢复字符串原来的顺序,便于下次遍历
s
=
'abc'
global
str_list
str_list
=
[]
str_sort(s,
0
)
print
(
len
(str_list), str_list)
|
这种方法在求解的思路上就已经有了很大的提升,不是像上一个靠“蛮力”去解决问题,这是递归的一种方式,大概原理就是,先保持前I个字符不变,遍历交换后边的字符,这样一直递归到,最后两个字符,然后再返回去改变倒数第三个字符,再次遍历后边的两位,直到三个字符的全部输出,也就是这样的顺序, 。
第一次输出 X(n),X(n-1),X(n-2),......X(3),X(2),X(1) 。
第二次输出 X(n),X(n-1),X(n-2),......X(3),X(1),X(2) 。
第三次输出 X(n),X(n-1),X(n-2),......X(2),X(3),X(1) 。
第四次输出 X(n),X(n-1),X(n-2),......X(2),X(1),X(3) 。
...... 。
这个可能我讲的不是特别清楚,理解起来不是特别容易,这种方式经过我的测试,发现他更费时.
自我感觉两种方法区别不大,原理上是一样的,都是先确定前面的部分,处理后边的,从后往前走.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:http://www.cnblogs.com/7749ha/p/9011093.html 。
最后此篇关于python3实现字符串的全排列的方法(无重复字符)的文章就讲到这里了,如果你想了解更多关于python3实现字符串的全排列的方法(无重复字符)的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
Apache服务器全局配置之服务器标识配置篇 服务器标识相关指令: ServerName ServerAdmin ServerSignature ServerTokens UseCanonical
//校验是否全由数字组成 ? 1
具体内容如下: 1 os.system 例如 ipython中运行如下命令,返回运行状态status os.system('cat /etc/passwdqc.conf') min=disab
基本操作 查看数据库 ? 1
Xcode使用教程详细讲解是本文要介绍的内容,Xcode是一个款强大的IDE开发环境,就像你在写Windows程序时需要VS2005一样 需要要Xcode为你写Mac程序提供环境。因此,如果你要成为
就如今天遇到随即函数rand();脑海中想到用它做点啥好呢,最后想起了验证码,数字验证码,字母验证码,中文验证码,可是自己不会呀,咋办呢,上网搜,看别人的代码,开不懂,看视频,听老师讲,将其中所遇到
pcre-7.8.tar.gz 正则表达式下载地址:ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/
IDEA常用设置(提高开发效率) 本人也是IDEA编译器的忠实用户了,但是有时出于各种原因,比如更换设备等等,IDEA总是需要重新安装配置。这就让我比较苦恼,因为总是记不全自己之前都修改了
? 1 2
1、 操作环境搭建 系统:Windows7 旗舰版 64位 PHP环境:wampserver2.2e-php5.4.3-httpd2.2.22-mysql5.5.24 32
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 去年关闭。 Improve th
我已经为我在 Adobe Fireworks Cs5 中构建的页面生成了 css,我想知道如何为我的标题和其他 div 设置完整宽度。我将显示标题部分的 css 代码。 @charset "utf
您好,我希望表单宽度为 100%。我希望文本框几乎延伸整个页面的宽度,并在文本框的右侧直接放置小的“GO”按钮,所有按钮都在同一行(或 block )上。 现在我的文本框只有其中文本的宽度(“在此处输
我没有设法将全宽页脚粘贴到网页底部。当页脚上方的主要内容低于一定高度时,页脚下方有一个空白区域。我尝试使用各种解决方案,例如以下 css 代码: html,body { margin:0; padd
我想要一个全宽的表格。当我给 position:fixed; 它变成全宽但可滚动不起作用。 简而言之,我需要一个与浏览器主体没有任何边距的表格。 body { font-family: "Helv
我注意到很多大型网站(如 Google 和 Facebook)在查看页面源代码时 99% 的源代码都是 JavaScript。 有人知道这种方法相对于常规 HTML+JavaScript 页面的优势吗
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 8 年前。 Improve this q
由于某种原因,我网站上的图片不再是全宽的。 据我所见,所有内容都设置为 100% 宽度。 http://cargocollective.com/btatest 我是不是什么地方都没有? 最佳答案 我认
我正在创建一个菜单并尝试使用 CSS 制作全宽菜单。但是,我不确定菜单项将如何出现在菜单中。 这是问题的截图: 问题出在我得到的“GAP”中。 如果我有固定数量的元素,我知道我可以使用这个逻辑: ul
这个问题在这里已经有了答案: Puzzle: Find largest rectangle (maximal rectangle problem) (6 个答案) 关闭 9 年前。 给定一个二元矩阵
我是一名优秀的程序员,十分优秀!