| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2489 人关注过本帖
标题:数字1到9,如何把所有排列付给数组?
只看楼主 加入收藏
zqj417
Rank: 1
等 级:新手上路
帖 子:55
专家分:0
注 册:2006-2-16
收藏
 问题点数:0 回复次数:13 
数字1到9,如何把所有排列付给数组?

想不出来啊,就算套9个循环也很难判定啊

怀疑是不是有库函数啊

搜索更多相关主题的帖子: 排列 数字 函数 
2006-02-22 23:02
feng1256
Rank: 4
等 级:贵宾
威 望:14
帖 子:2899
专家分:0
注 册:2005-11-24
收藏
得分:0 
要找出所有排列?这也太多了

叁蓙大山:工謪、稅務、嗣發 抱歉:不回答女人的问题
2006-02-22 23:04
zqj417
Rank: 1
等 级:新手上路
帖 子:55
专家分:0
注 册:2006-2-16
收藏
得分:0 
多不是问题啊
关键我连最奔的算法都没有
2006-02-22 23:12
zqj417
Rank: 1
等 级:新手上路
帖 子:55
专家分:0
注 册:2006-2-16
收藏
得分:0 
不是说把所有排列都给数组

是每次把一个排列给数组判断后在排列下一个
2006-02-22 23:26
feng1256
Rank: 4
等 级:贵宾
威 望:14
帖 子:2899
专家分:0
注 册:2005-11-24
收藏
得分:0 
是每次把一个排列给数组判断后在排列下一个

判断什么?


叁蓙大山:工謪、稅務、嗣發 抱歉:不回答女人的问题
2006-02-23 01:08
cordier
Rank: 2
等 级:论坛游民
威 望:1
帖 子:449
专家分:14
注 册:2006-2-9
收藏
得分:0 
我觉得可以这样,你用一个long n的变量。
让它从0到999999999循环,你只要取出n中的每一位不就可以了。

上面只是我的个人想法。不知道高手有没有更高的想法。
不要保留嘛

2006-02-23 10:13
zqj417
Rank: 1
等 级:新手上路
帖 子:55
专家分:0
注 册:2006-2-16
收藏
得分:0 
以下是引用cordier在2006-2-23 10:13:00的发言:
我觉得可以这样,你用一个long n的变量。
让它从0到999999999循环,你只要取出n中的每一位不就可以了。

上面只是我的个人想法。不知道高手有没有更高的想法。
不要保留嘛

对数字来说可行
但是要是内容一变,比如变成字母就不好办了啊

2006-02-23 14:55
柳儿
Rank: 6Rank: 6
等 级:贵宾
威 望:25
帖 子:1830
专家分:30
注 册:2004-9-23
收藏
得分:0 
是排列组合么?

成功会使人骄傲。如果你骄傲自大,你就会停止学习。不学习,人就停止了进步
2006-02-23 15:00
zqj417
Rank: 1
等 级:新手上路
帖 子:55
专家分:0
注 册:2006-2-16
收藏
得分:0 
是排列不是组合
2006-02-23 15:08
柳儿
Rank: 6Rank: 6
等 级:贵宾
威 望:25
帖 子:1830
专家分:30
注 册:2004-9-23
收藏
得分:0 
char s[10], t[10];

void convert(char *strSource, char *strTarget, int nLen)
{
int i, j;
char strConvert[10];

if(nLen == 1) {
strTarget[0] = strSource[0];
printf("%s\n", t);
return;
}
else {
for(i=0; i<nLen; i++) {
for(j=0; j<i && strSource[i] != strSource[j]; j++);
if(j == i) {
strTarget[0] = strSource[i];
memcpy(strConvert, strSource, i);
memcpy(strConvert+i, strSource+i+1, nLen-i-1);
convert(strConvert, strTarget+1, nLen-1);
}
}
}
}

main()
{
int n;

scanf("%d", &n);
sprintf(s, "%d", n);

memset(t, 0, 10);
convert(s, t, strlen(s));
}
据说这个重复情况挺多。

成功会使人骄傲。如果你骄傲自大,你就会停止学习。不学习,人就停止了进步
2006-02-23 15:39
快速回复:数字1到9,如何把所有排列付给数组?
数据加载中...
 
   



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

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