文章详情页
java - 请问这种排列算法的难度在什么水平?
浏览:195日期:2024-02-07 11:53:09
问题描述
https://segmentfault.com/q/10... 这个问题中有四种对4位整型数组进行排列组合的算法,一个一个按照运行顺序写下来觉得很有意思,我肯定直接写不出来,想问一下算法界的大神们,这种算法大概是什么水平的?如果是很简单的那种,我大概真的要去补一下了...另外,除了死记硬背,这么刁钻的设计是怎么想出来的...
问题解答
回答1:全排列的过程可以当成树的遍历过程,每个叶子节点就是一种排列,只不过要注意的是每个子树的边不能和父节点的边重复。 树的遍历过程好办,或递归或用栈或队列甚至另外设置个保存状态的数组都行,子树的边不能和父节点边重复的问题也好办,遍历子树的时候只遍历available的,并且遍历后做标记就可以了。 我觉得这个问题转换成树就好办了,实现各种各样都可以吧。
标签:
java
相关文章:
1. redis sentinel怎么跑守护进程以及日志记录位置的?2. 在windows下安装docker Toolbox 启动Docker Quickstart Terminal 失败!3. javascript - sublime快键键问题4. 前端 - 这段代码一直生效不了,查半天因为 top: 0px; 分号后一个隐藏的东西,也不是占位符...删了就可以生效,这是什么情况。。5. django - Nginx uwsgi 进程问题6. javascript - 解释下这种函数定义7. 百度地图api - Android百度地图SDK,MapView上层按钮可见却不可触,怎么解决?8. html5 - ElementUI table中el-table-column怎么设置百分比显示。9. javascript - 爱加密的HTML5应用加固服务是什么原理?10. 关于纯用css写导航鼠标移入事件的问题?
排行榜

网公网安备