| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 4870 人关注过本帖
标题:编程序写出1到9的全排列
只看楼主 加入收藏
lowrie
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:81
专家分:138
注 册:2015-3-12
结帖率:87.5%
收藏
已结贴  问题点数:50 回复次数:25 
编程序写出1到9的全排列
编写程序写出1到9的全排列,各位都有什么好的想法
搜索更多相关主题的帖子: 编写程序 
2015-06-17 19:40
我爱吃青菜
Rank: 7Rank: 7Rank: 7
等 级:黑侠
威 望:6
帖 子:190
专家分:500
注 册:2015-3-29
收藏
得分:5 
网上抄的
http://zhidao.baidu.com/link?url=w9uOsBFmhzh5NRGep-D4XK9GGIF5JO5z7_-IDTJO53oeM2gxcH6WzNuMmRMd_JKK0sYJZrJ23f-sbomYdjgiEa

程序代码:
#include <stdio.h>  

int n = 0;  

void swap(int *a, int *b) 
{     
    int m;     
     m = *a;     
    *a = *b;     
    *b = m; 
}  
void perm(int list[], int k, int m) 
{     
    int i;     
    if(k > m)     
     {          
        for(i = 0; i <= m; i++)             
             printf("%d ", list[i]);         
         printf("\n");         
         n++;     
     }     
    else     
     {         
        for(i = k; i <= m; i++)         
         {             
             swap(&list[k], &list[i]);             
             perm(list, k + 1, m);             
             swap(&list[k], &list[i]);         
         }     
     } 
} 
int main() 
{     
    int list[] = {1, 2, 3, 4, 5, 6, 7, 8, 9};     
     perm(list, 0, 8);     
     printf("total:%d\n", n);     
    return 0; 
} 
2015-06-17 22:51
BlueGuy
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:29
帖 子:4476
专家分:4055
注 册:2009-4-18
收藏
得分:0 
自己在纸上先画出来全排列,然后用程序模拟计算的过程。  
非常简单, 我不信还有谁全排列不会算。

如果你学过 深度优先搜索,应该更容易理解,

[ 本帖最后由 BlueGuy 于 2015-6-17 23:03 编辑 ]

我就是真命天子,顺我者生,逆我者死!
2015-06-17 22:57
BlueGuy
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:29
帖 子:4476
专家分:4055
注 册:2009-4-18
收藏
得分:0 
楼主,你说说 1- 9的全排列手工怎么算的

我就是真命天子,顺我者生,逆我者死!
2015-06-17 23:11
lowrie
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:81
专家分:138
注 册:2015-3-12
收藏
得分:0 
手算很简单,9的阶乘,但不好用代码实现,所以想问下有没有什么好的办法,我的想法是把111111111到999999999的数遍历一遍,但感觉方法不可取,二楼的方法在在网上看到过,还没具体研究
2015-06-17 23:26
BlueGuy
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:29
帖 子:4476
专家分:4055
注 册:2009-4-18
收藏
得分:0 
回复 5楼 lowrie
你手工把1-4的排列从1到4画出来,然后找规律,
2楼的代码很烂,不用看他的,递归你可能不会写,1-9的循环求排列你会写吗?

我就是真命天子,顺我者生,逆我者死!
2015-06-17 23:33
BlueGuy
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:29
帖 子:4476
专家分:4055
注 册:2009-4-18
收藏
得分:0 
你先用9层循环把排列求出来,然后再想办法把循环改成递归。
这个题很简单,如果9个数你不会,你就改成2个数

[ 本帖最后由 BlueGuy 于 2015-6-17 23:40 编辑 ]

我就是真命天子,顺我者生,逆我者死!
2015-06-17 23:37
lowrie
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:81
专家分:138
注 册:2015-3-12
收藏
得分:0 
也想过递归,但一直想不出好的方法,所以才问的,9层循环很好弄,写过了,就是转成递归有点困难,没想到好的办法
2015-06-17 23:46
BlueGuy
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:29
帖 子:4476
专家分:4055
注 册:2009-4-18
收藏
得分:0 
以下是引用lowrie在2015-6-17 23:46:44的发言:

也想过递归,但一直想不出好的方法,所以才问的,9层循环很好弄,写过了,就是转成递归有点困难,没想到好的办法

我明天上午帮你写一份代码,

我就是真命天子,顺我者生,逆我者死!
2015-06-17 23:49
BlueGuy
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:29
帖 子:4476
专家分:4055
注 册:2009-4-18
收藏
得分:0 
以下是引用边小白在2015-6-18 06:05:48的发言:

排多少位也不说,一位不就是1-9、,2位就11-99,剔除有0的数,如此下去,是不是很简单?不要听某些人假高,简单问题复杂化。

我肯定你2年后都写不出来这道题

我就是真命天子,顺我者生,逆我者死!
2015-06-18 06:40
快速回复:编程序写出1到9的全排列
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.024733 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved