| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 573 人关注过本帖
标题:出错在哪,谢谢指导
只看楼主 加入收藏
多余的流星
Rank: 1
等 级:新手上路
帖 子:47
专家分:0
注 册:2011-5-2
结帖率:69.23%
收藏
已结贴  问题点数:20 回复次数:8 
出错在哪,谢谢指导
#include <stdio.h>
# define maxsize 100
main(  )
{
    struct Sqlist{
        int elem[maxsize];
        int length;
    };
    int i,j,e,k;
    struct Sqlist la,lb,lc;
    printf("请输入集合A、集合B的元素个数\n");
    scanf("%d %d",&la.length,&lb.length);
    printf("请输入集合A的元素\n");
    for(i=0;i<la.length;i++)
        scanf("%d",&la.elem[i]);
    printf("请输入集合B的元素\n");
    for(i=0;i<lb.length;i++)
        scanf("%d",&lb.elem[i]);

   
   
//求A与B的并集
    for(i=0;i<lb.length;i++)
    {
        e=lb.elem[i];
        j=0;
        while((j<la.length)&&(la.elem[j]!=e))
            j++;
        if(j==la.length)
        {
            la.elem[la.length]=e;
            la.length++;
        }
    }
    printf("并集中的元素为:\n");
    for(i=0;i<la.length;i++)
        printf("%d\t",la.elem[i]);
    printf("\n");


    //求A和B的交集
    for(i=0;i<lb.length;i++)
    {
        e=lb.elem[i];
        j=0,k=0;
        while(j<la.length)
        {
            if(la.elem[j]==e)
            {
            lc.elem[k]=e;
            k++;
            }
            j++;
        }
        lc.length=k;
        
        
   
   
    }
    printf("交集中的元素为:\n");
    for(k=0;k<lc.length;k++)
        printf("%d\t",lc.elem[k]);

    printf("\n");














}
搜索更多相关主题的帖子: include 元素 
2011-09-21 17:36
embed_xuel
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:58
帖 子:3845
专家分:11385
注 册:2011-9-13
收藏
得分:7 
回复 楼主 多余的流星
你红色代码部分对变量k使用不对吧,每次都清零

总有那身价贱的人给作业贴回复完整的代码
2011-09-21 19:06
多余的流星
Rank: 1
等 级:新手上路
帖 子:47
专家分:0
注 册:2011-5-2
收藏
得分:0 
回复 2楼 xugaige
错误是并不能得到所要的结果,红色部分是求A和B的交集但我所写的程序并不能运行得到结果,请问该怎么改
2011-09-21 20:33
唯我独魔
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:176
专家分:782
注 册:2011-4-13
收藏
得分:7 
应该可以了,自己看我改了哪里吧,不懂问我好了
#include <stdio.h>
# define maxsize 100
main(  )
{
    struct Sqlist{
        int elem[maxsize];
        int length;
    };
    int i,j,e,k;
    struct Sqlist la,lb;
    struct list{
        int elem[2*maxsize];
        int length;
    } lc;
    printf("请输入集合A、集合B的元素个数\n");
    scanf("%d %d",&la.length,&lb.length);
    printf("请输入集合A的元素\n");
    for(i=0;i<la.length;i++)
        scanf("%d",&la.elem[i]);
    printf("请输入集合B的元素\n");
    for(i=0;i<lb.length;i++)
        scanf("%d",&lb.elem[i]);

   
   
//求A与B的并集
    lc.length=la.length;
    for(i=0;i<la.length;i++)
        lc.elem[i]=la.elem[i];
    for(i=0;i<lb.length;i++)
    {
        e=lb.elem[i];
        j=0;
        while((j<lc.length)&&(lc.elem[j]!=e))
            j++;
        if(j==lc.length)
        {
            lc.elem[j]=e;
            lc.length++;
        }
    }
    printf("并集中的元素为:\n");
    for(i=0;i<lc.length;i++)
        printf("%d\t",lc.elem[i]);
    printf("\n");


    //求A和B的交集
    k=0;
    for(i=0;i<lb.length;i++)
    {
        e=lb.elem[i];
        j=0;
        while(j<la.length)
        {
            if(la.elem[j]==e)
            {
            lc.elem[k]=e;
            k++;
            break;
            }
            j++;
        }
    }
    lc.length=k;
    printf("交集中的元素为:\n");
    for(k=0;k<lc.length;k++)
        printf("%d\t",lc.elem[k]);

    printf("\n");
}
2011-09-21 21:00
多余的流星
Rank: 1
等 级:新手上路
帖 子:47
专家分:0
注 册:2011-5-2
收藏
得分:0 
回复 5楼 唯我独魔
   我觉得求差的原理和求交集应该差不多,可为什么不能运行呢,求指导!!谢谢


 //求A和B的差

    k=0;
    for(i=0;i<la.length;i++)
    {
        e=la.elem[i];
        j=0;
        while(j<lb.length)
        {
            if(lb.elem[j]!=e)
            {
            ld.elem[k]=e;
            k++;
            break;
            }
            j++;
        }
    }
    ld.length=k;
    printf("A-B中元素为:\n");
    for(i=0;k<ld.length;i++)
        printf("%d\t",ld.elem[i]);

    printf("\n");

2011-09-21 22:03
唯我独魔
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:176
专家分:782
注 册:2011-4-13
收藏
得分:0 
继续自己看,不懂继续问我
#include <stdio.h>
# define maxsize 100
main(  )
{
    struct Sqlist{
        int elem[maxsize];
        int length;
    };
    int i,j,e,k;
    struct Sqlist la,lb;
    struct list{
        int elem[2*maxsize];
        int length;
    } lc,ld;
    printf("请输入集合A、集合B的元素个数\n");
    scanf("%d %d",&la.length,&lb.length);
    printf("请输入集合A的元素\n");
    for(i=0;i<la.length;i++)
        scanf("%d",&la.elem[i]);
    printf("请输入集合B的元素\n");
    for(i=0;i<lb.length;i++)
        scanf("%d",&lb.elem[i]);

   
   
//求A与B的并集
    lc.length=la.length;
    for(i=0;i<la.length;i++)
        lc.elem[i]=la.elem[i];
    for(i=0;i<lb.length;i++)
    {
        e=lb.elem[i];
        j=0;
        while((j<lc.length)&&(lc.elem[j]!=e))
            j++;
        if(j==lc.length)
        {
            lc.elem[j]=e;
            lc.length++;
        }
    }
    printf("并集中的元素为:\n");
    for(i=0;i<lc.length;i++)
        printf("%d\t",lc.elem[i]);
    printf("\n");


    //求A和B的交集
    k=0;
    for(i=0;i<lb.length;i++)
    {
        e=lb.elem[i];
        j=0;
        while(j<la.length)
        {
            if(la.elem[j]==e)
            {
            lc.elem[k]=e;
            k++;
            break;
            }
            j++;
        }
    }
    lc.length=k;
    printf("交集中的元素为:\n");
    for(k=0;k<lc.length;k++)
        printf("%d\t",lc.elem[k]);

    printf("\n");

//求A和B的差(属于A但是不属于B)

    k=0;
    for(i=0;i<la.length;i++)
    {
        e=la.elem[i];
        j=0;
        while(j<lb.length)
        {
            if(lb.elem[j]==e)
                break;
            j++;
        }
        if(j==lb.length)
        {
            ld.elem[k]=e;
            k++;
        }
    }
    ld.length=k;
    printf("A-B中元素为:\n");
    for(i=0;i<ld.length;i++)
        printf("%d\t",ld.elem[i]);

    printf("\n");


}
2011-09-21 22:28
多余的流星
Rank: 1
等 级:新手上路
帖 子:47
专家分:0
注 册:2011-5-2
收藏
得分:0 
回复 7楼 唯我独魔
我想了很久还是没有想明白,红色部分如何理解,求解释,谢谢哈



//求A和B的差(属于A但是不属于B)

    k=0;
    for(i=0;i<la.length;i++)
    {
        e=la.elem[i];
        j=0;
        while(j<lb.length)
        {
            if(lb.elem[j]==e)
                break;
            j++;
        }
       if(j==lb.length)
        {
            ld.elem[k]=e;
            k++;
        }
    }
    ld.length=k;
    printf("A-B中元素为:\n");
    for(i=0;i<ld.length;i++)
        printf("%d\t",ld.elem[i]);

    printf("\n");
2011-09-22 13:13
唯我独魔
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:176
专家分:782
注 册:2011-4-13
收藏
得分:0 
额。。。就是说A中的每一个元素去B中找,如果没找到,那么就是差集中的,红色部分就是用来判断在B中是否没有找到,没有找到,则加入差集ld中
2011-09-22 14:05
快速回复:出错在哪,谢谢指导
数据加载中...
 
   



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

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