| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 470 人关注过本帖
标题:下面这个程序怎么修改,使其达到要求?
只看楼主 加入收藏
AA2979787204
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2014-6-6
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:9 
下面这个程序怎么修改,使其达到要求?
#include<stdio.h>

int main()
{
    int A[10]={1,2,3,4,5,6,7,8,9,10};  
    int B[5]={11,12,13,14,15};  
    int C[5]={16,17,18,19,20};  
    int i, j, k, m, n, p;
    int cont=0;            

    for (i = 0; i < 10; i++) {
        for (j = 0; j < 10; j++)
            if (j != i)
                for (k = 0; k < 10; k++)
                    if (k != i && k != j)
                        for (m = 0; m < 5; m++)
                            for (n = 0; n < 5; n++)
                                if (n != m)
                                    for (p = 0; p < 5; p++) {
                                        printf("%d %d %d %d %d %d\n", A[i], A[j], A[k], B[m], B[n], C[p]);                                              cont++;                                                    }
   
    }
    printf("%d\n", cont);        
    return 0;
}
运行结果如下:(1)1 2 3 11 12 16
              (2)1 2 3 11 12 17
              (3)1 2 3 11 12 18
                   。。。。。。
              (51)1 2 3 12 11 16
              (52)1 2 3 12 11 17
              (53)1 2 3 12 11 18
                    。。。。。。
要求:1.从上面部分运行结果中可看出,(1)与(51)是一样的,怎样剔除重复的运行结果,只留其中一个?
搜索更多相关主题的帖子: include 
2014-09-08 16:59
wssy213
Rank: 12Rank: 12Rank: 12
来 自:湖南
等 级:贵宾
威 望:10
帖 子:967
专家分:3703
注 册:2014-6-6
收藏
得分:10 
是说各行中的数字都不能相同吗?没有理解你的问题

坚持----------------------------------唯一的道路
shit ! ! !
2014-09-08 19:11
AA2979787204
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2014-6-6
收藏
得分:0 
回复 2 楼 wssy213
(1)1 2 3 11 12 16
(2)1 2 3 11 12 17
     。。。。。。
(51)1 2 3 12 11 16
意思是:比如其中(1)和(2)的结果是不一样的,但是(1)和(51)的结果是一样的,只是数字位置不一样,但最终结果都是1 2 3 11 12 16,剔除掉(51)就好了哈。
2014-09-08 19:52
wssy213
Rank: 12Rank: 12Rank: 12
来 自:湖南
等 级:贵宾
威 望:10
帖 子:967
专家分:3703
注 册:2014-6-6
收藏
得分:0 
可以理解为后面的数字一定要大于前面的数字吗?若是,修改如下:
#include<stdio.h>

int main()
{
    int A[10]={1,2,3,4,5,6,7,8,9,10};  
    int B[5]={11,12,13,14,15};  
    int C[5]={16,17,18,19,20};  
    int i, j, k, m, n, p;
    int cont=0;            

    for (i = 0; i <=4; i++) {
        for (j = i+1; j <=4; j++)
            //if (j != i)
                for (k = j+1; k <=4; k++)
                    //if (k != i && k != j)
                        for (m = 0; m <=4; m++)
                            for (n = m+1; n <=4; n++)
                                //if (n != m)
                                    for (p = 0; p < 5; p++) {
                                        printf("%d %d %d %d %d %d\n", A[i], A[j], A[k], B[m], B[n], C[p]);                                              cont++;                                                    }
   
    }
    printf("%d\n", cont);        
    return 0;
}

坚持----------------------------------唯一的道路
shit ! ! !
2014-09-08 20:40
AA2979787204
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2014-6-6
收藏
得分:0 
回复 4 楼 wssy213
不是,是组合问题,不是排列问题(运行结果不必按大小顺序排列)哈!
如果改成int A[10]={3,4,5,8,9,10,13,14,17,19};  
        int B[5]={1,2,11,12,15};  
        int C[5]={6,7,16,18,20};
部分运行结果如下:(1)3 8 9 1 15 18
                  (2) 3 8 9 1 15 20
                  (3)3 8 9 2 11 6
                       。。。。。。
而且该源程序的本题是:从数组A中抽取3个数,数组B中抽取2个数,数组C中抽取1个数,组成6个数的组合,并列出所有运行结果,求源程序。
2014-09-08 21:38
erty1001
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:4
帖 子:331
专家分:1433
注 册:2014-8-31
收藏
得分:10 
简单说说
代码要有整体感

#include<stdio.h>

int main()
{
    int A[10]={1,2,3,4,5,6,7,8,9,10};   //选3个
    int B[5]={11,12,13,14,15};        //选2个
    int C[5]={16,17,18,19,20};         //选1个
    int i, j, k, m, n, p;
    int cont=0;  

    for (i = 0; i < 10; i++)
    {
        for (j = i+1; j < 10; j++)
        {
            for (k = j+1; k < 10; k++)
            {
                for (m = 0; m < 5; m++)
                {
                    for (n = m+1; n < 5; n++)
                    {
                        for (p = 0; p < 5; p++)
                        {
                            cont++;   
                            printf("%d %d %d %d %d %d\n", A[i], A[j], A[k], B[m], B[n], C[p]);

                        }
                    }

                }

            }

        }
    }      



    printf("%d\n", cont);        
    return 0;
}
2014-09-08 21:47
erty1001
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:4
帖 子:331
专家分:1433
注 册:2014-8-31
收藏
得分:0 
简单说说
代码要有整体感

#include<stdio.h>

int main()
{
    int A[10]={1,2,3,4,5,6,7,8,9,10};   //选3个
    int B[5]={11,12,13,14,15};        //选2个
    int C[5]={16,17,18,19,20};         //选1个
    int i, j, k, m, n, p;
    int cont=0;  

    for (i = 0; i < 10; i++)
    {
        for (j = i+1; j < 10; j++)
        {
            for (k = j+1; k < 10; k++)
            {
                for (m = 0; m < 5; m++)
                {
                    for (n = m+1; n < 5; n++)
                    {
                        for (p = 0; p < 5; p++)
                        {
                            cont++;   
                            printf("%d %d %d %d %d %d\n", A[i], A[j], A[k], B[m], B[n], C[p]);

                        }
                    }

                }

            }

        }
    }      



    printf("%d\n", cont);        
    return 0;
}
2014-09-08 21:47
AA2979787204
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2014-6-6
收藏
得分:0 
回复 6 楼 erty1001
OK! 谢谢啦。
2014-09-08 22:04
随风而行lulu
Rank: 2
等 级:论坛游民
帖 子:59
专家分:60
注 册:2014-9-6
收藏
得分:0 
什么意思?
2014-09-11 21:22
随风而行lulu
Rank: 2
等 级:论坛游民
帖 子:59
专家分:60
注 册:2014-9-6
收藏
得分:0 
以下是引用erty1001在2014-9-8 21:47:55的发言:

简单说说
代码要有整体感

#include<stdio.h>

int main()
{
    int A[10]={1,2,3,4,5,6,7,8,9,10};   //选3个
    int B[5]={11,12,13,14,15};        //选2个
    int C[5]={16,17,18,19,20};         //选1个
    int i, j, k, m, n, p;
    int cont=0;  

    for (i = 0; i < 10; i++)
    {
        for (j = i+1; j < 10; j++)
        {
            for (k = j+1; k < 10; k++)
            {
                for (m = 0; m < 5; m++)
                {
                    for (n = m+1; n < 5; n++)
                    {
                        for (p = 0; p < 5; p++)
                        {
                            cont++;   
                            printf("%d %d %d %d %d %d\n", A, A[j], A[k], B[m], B[n], C[p]);

                        }
                    }

                }

            }

        }
    }      



    printf("%d\n", cont);        
    return 0;
}


我个人喜欢这种对称的写法,不知道为什么很多人都把{写在上一行的末尾?
2014-09-11 21:25
快速回复:下面这个程序怎么修改,使其达到要求?
数据加载中...
 
   



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

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