| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 450 人关注过本帖
标题:请教一个函数与链表指针的问题
只看楼主 加入收藏
zd123
Rank: 2
等 级:论坛游民
帖 子:43
专家分:33
注 册:2009-9-4
结帖率:70%
收藏
已结贴  问题点数:20 回复次数:4 
请教一个函数与链表指针的问题
可以这样做吗?
在主函数里创建一个函数,此函数调用两个链表指针,然后在函数里创建第三个链表,那第三个链表能返回吗???
snode * fanhui(snode *head1,snode *head2)
{
  sonde *head;
    .
    .
    .
  return head;
}
如果不可以的话,要怎么做?
搜索更多相关主题的帖子: 函数 指针 链表 
2009-09-06 11:52
huangxiancon
Rank: 2
等 级:论坛游民
帖 子:7
专家分:33
注 册:2009-8-30
收藏
得分:7 
这个应该可以。
2009-09-06 12:12
zd123
Rank: 2
等 级:论坛游民
帖 子:43
专家分:33
注 册:2009-9-4
收藏
得分:0 
还有人知道吗?
2009-09-06 18:42
迷途流浪
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:20
专家分:139
注 册:2009-9-6
收藏
得分:7 
模糊理解你的说法,应该可以
最好是把代码贴出来
2009-09-06 19:03
zd123
Rank: 2
等 级:论坛游民
帖 子:43
专家分:33
注 册:2009-9-4
收藏
得分:0 
回复 4楼 迷途流浪
求两个链表的差

#include"stdio.h"
#include"malloc.h"
#include"stdlib.h"
#define SIZE sizeof(snode)
typedef struct student
{
    int num;
    struct student *next;
}snode;
snode *create1();
snode *create2();                           //创建链表
void print(snode *head);                    //打印链表
snode *diffence(snode *A,snode *B);
void main(void)
{
    snode *head2,*head1,*head3;
    head1=create1();  
    head2=create2();
    printf("\n链表1为:\n");
    print(head1);
    printf("\n链表2为:\n");
    print(head2);
    printf("\n");
    printf("两链表的差为:\n");
    head3=diffence(head1,head2);
    print(head3);
    printf("\n");
}
snode *create1()
{
    snode *head,*p,*q;
    p=q=(snode *)malloc(sizeof(SIZE));
    head=(snode *)malloc(sizeof(SIZE));
    int n=0,num1;
    FILE *fp;
    fp=fopen("D:\\qq.txt","r");
    fscanf(fp,"%d",&num1);
    p->num=num1;
    while(!feof(fp))               //   
    {
        n++;
        if(n==1)
            head->next=p;            //建立带头节点的链表
        else
            q->next=p;
        q=p;
        p=(snode *)malloc(sizeof(SIZE));
        fscanf(fp,"%d",&num1);
        p->num=num1;
    }
    q->next=NULL;
    return (head);
}
snode *create2()
{
    snode *head,*p,*q;
    p=q=(snode *)malloc(sizeof(SIZE));
    head=(snode *)malloc(sizeof(SIZE));
    int n=0,num1;
    FILE *fp;
    fp=fopen("D:\\aa.txt","r");
    fscanf(fp,"%d",&num1);
    p->num=num1;
    while(!feof(fp))               //这
    {
        n++;
        if(n==1)
            head->next=p;            //建立带头节点的链表
        else
            q->next=p;
        q=p;
        p=(snode *)malloc(sizeof(SIZE));
        fscanf(fp,"%d",&num1);
        p->num=num1;
    }
    q->next=NULL;
    return (head);
}
void print(snode *head)
{
    snode *p;
    p=head->next;                 //带头结点
    while(p!=NULL)
    {
        printf("%6d",p->num);
        p=p->next;
    }
}
snode *diffence(snode *A,snode *B)
{
    snode *pa=A->next,*pb,*s,*r,*c;
    c=(snode *)malloc(sizeof(SIZE));
    c->next=NULL;
    r=c;
    while(pa!=NULL)                             
    {
        pb=B->next;
        while(pb->num!=pa->num && pb!=NULL)
        {
            pb=pb->next;
        }
        if(pb=NULL)
        {
            s=(snode *)malloc(sizeof(SIZE));
            s->num=pa->num;s->next=NULL;
            r->next=s;
            r=s;
        }
        pa=pa->next;
    }
    return(c);
}


[ 本帖最后由 zd123 于 2009-9-6 21:29 编辑 ]
2009-09-06 19:51
快速回复:请教一个函数与链表指针的问题
数据加载中...
 
   



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

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