| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 512 人关注过本帖
标题:一个程序 大家看看有什么问题吗??
只看楼主 加入收藏
yuancht
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2010-3-30
结帖率:0
收藏
已结贴  问题点数:20 回复次数:6 
一个程序 大家看看有什么问题吗??
运行了下 怎么有重复的  这是怎么回事?请各位大侠指点
#include<stdio.h>
#include<math.h>
#define N 8
#define M 5
void check(int p[]){
int i,j;

for(i=0;i<N;i++)
  for(j=i+1;j<N;j++)
   if(p[i]*p[j]!=0){
    if(abs(p[j]-p[i])==j-i)
     return;
      if(p[j]-p[i]==0) return;
         }

   

      for(i=0;i<N;i++)
 printf("%d",p[i]);
        printf("\n");

 }
void permute(int n,int p[]){
int i,j,count;
if(n==1)
  check(p);
   for(i=0,count=n-1;i<N;i++)
   if(!p[i]){
 for(j=i+1;j<N+1;j++)
    {
     p[i]=j;
   permute(count,p);
    p[i]=0;
     }
     }
     }
     int main(){
      static int p[N];
      int n=M;

      permute(n+1,p);

      return 0;
      }
搜索更多相关主题的帖子: include return count 
2010-04-03 18:52
hahayezhe
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖南张家界
等 级:贵宾
威 望:24
帖 子:1386
专家分:6999
注 册:2010-3-8
收藏
得分:4 
痛苦 !!!!!!!!!!!!!!!
2010-04-03 19:19
yuancht
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2010-3-30
收藏
得分:0 
回复 2楼 hahayezhe
咋了???
2010-04-03 19:26
ggvvcc
Rank: 3Rank: 3
来 自:山东临沂
等 级:论坛游侠
帖 子:50
专家分:119
注 册:2010-4-3
收藏
得分:4 
#include<stdio.h>
#include<math.h>

#define N 8
#define M 5

void check(int p[]){
    int i,j;

    for(i=0;i<N;i++)
        for(j=i+1;j<N;j++)
            if(p[i]*p[j]!=0){
                if(abs(p[j]-p[i])==j-i)
                    return;
                if(p[j]-p[i]==0)
                    return;
             }

    for(i=0;i<N;i++)
        printf("%d",p[i]);

    printf("\n");

}

void permute(int n,int p[]){
    int i,j,count;
    if(n==1) check(p);
    for(i=0,count=n-1;i<N;i++)
        if(!p[i])
            for(j=i+1;j<N+1;j++){
                p[i]=j;
                permute(count,p);
                p[i]=0;
            }

}


int main(){
     static int p[N];
     int n=M;

     permute(n+1,p);

     return 0;
}

运行了一下,好像有死循环,不会做,给你排排版。
2010-04-03 19:32
流云追风
Rank: 2
等 级:论坛游民
帖 子:15
专家分:16
注 册:2010-4-1
收藏
得分:4 
递归里套上2层循环。。。有得整。。。
2010-04-03 19:38
ltyjyufo
Rank: 9Rank: 9Rank: 9
来 自:未来
等 级:蜘蛛侠
威 望:2
帖 子:353
专家分:1166
注 册:2009-10-25
收藏
得分:4 
控制得好的话,用递归可以省很多事的

翱翔天空的雄鹰固然令人羡慕,却容易被禁锢于牢笼之中,只有那夜色中的蝙蝠才是真正自由的飞翔者....
2010-04-03 21:36
韩明海
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:253
专家分:749
注 册:2010-4-3
收藏
得分:4 
我现在不方便上级,大概在脑子里走了一下,不知道你看到没,当I=0时,进入循环,这时P【I】!=0;所以你再次调用permute时,程序什么都没做就出来了,然后p[i]=0;再想一想可知,每次permute时p[i]都是0;最后输出是全零么?
2010-04-03 22:59
快速回复:一个程序 大家看看有什么问题吗??
数据加载中...
 
   



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

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