文章详情页
java - 请问这种排列算法的难度在什么水平?
浏览:75日期:2024-02-07 11:53:09
问题描述
https://segmentfault.com/q/10... 这个问题中有四种对4位整型数组进行排列组合的算法,一个一个按照运行顺序写下来觉得很有意思,我肯定直接写不出来,想问一下算法界的大神们,这种算法大概是什么水平的?如果是很简单的那种,我大概真的要去补一下了...另外,除了死记硬背,这么刁钻的设计是怎么想出来的...
问题解答
回答1:全排列的过程可以当成树的遍历过程,每个叶子节点就是一种排列,只不过要注意的是每个子树的边不能和父节点的边重复。 树的遍历过程好办,或递归或用栈或队列甚至另外设置个保存状态的数组都行,子树的边不能和父节点边重复的问题也好办,遍历子树的时候只遍历available的,并且遍历后做标记就可以了。 我觉得这个问题转换成树就好办了,实现各种各样都可以吧。
标签:
java
相关文章:
1. javascript - 文件改后缀后怎么获得原来是什么类型的2. java - Tomcat 不同的域名访问同一个项目的不同网页3. docker安装后出现Cannot connect to the Docker daemon.4. python - pandas按照列A和列B分组,将列C求平均数,怎样才能生成一个列A,B,C的dataframe5. css3 - [CSS] 动画效果 3D翻转bug6. dockerfile - [docker build image失败- npm install]7. docker gitlab 如何git clone?8. docker-machine添加一个已有的docker主机问题9. 使用mysql自增主键遇到的问题10. javascript - IOS微信audio标签不能通过touchend播放
排行榜
