标题:如何建立单链表
只看楼主
瑶瑶1122333
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2011-11-24
结帖率:0
已结贴  问题点数:20 回复次数:3 
如何建立单链表
如何建立单链表
搜索更多相关主题的帖子: 如何 
2011-11-24 20:19
q982004342
Rank: 2
等 级:论坛游民
帖 子:19
专家分:25
注 册:2011-9-9
得分:7 
我不知道你看过数据结构这本书没,代码给你附上,是算法,不是完整的
程序代码:
/*结构定义*/
struct student

{

int num;                  /*学号*/

  float score;              /*成绩*/

  struct student *next;     /*指针域*/

};

/*构造单链表如下:*/

struct student *creat()     /*此函数返回一个指向链表的头结点*/

{ 

struct student *head;     /*指向student类型变量的指针head为头指针*/

  struct student *p,*tail;  /*tail指向链表末尾元素,p指向新分配的结点*/

  float temp;               /*临时数据变量*/

  head=NULL;

  do

  { 

    p=(struct student *)malloc(sizeof(struct student));/*分配新结点*/

printf(“Number Score:”);

    fflush(stdin);          /*清除输入缓冲区*/

    scanf("%d  %f",&p->num,&temp);

    if(p->num==0)

    {

      free(p);

      break;

    };

    p->score=temp;          /*取得结点数据*/

    p->next=NULL;

    if(head==NULL)

    {

      head=p;

      tail=p;

    }

    else

    {

      tail->next=p;

      tail=p;       /*指向尾结点*/

    }

  }while(p->num!=0);

  return(head);

}

多看课本,希望你能学好
2011-11-24 22:47
绿茶盖儿
Rank: 10Rank: 10Rank: 10
等 级:青峰侠
威 望:1
帖 子:363
专家分:1852
注 册:2011-9-3
得分:7 
还是好好看书吧
2011-11-27 12:05
jht727415
Rank: 2
等 级:论坛游民
帖 子:6
专家分:17
注 册:2011-11-23
得分:7 
有两种方法 尾插法和头插法
void CreatelistF(Snode*&L,ElemType A[],int n)
{
  Snode * s,int i;
  L=(Snode*)malloc(sizeof(Snode));
  L->next=NULL;
  for(i=0;i<n;i++)
{  
  S=(Snode*)malloc(sizeof(Snode));
  S->data=A[i];
  S->next=L->next;
  L->next=s;
}
}
 
2011-11-27 21:32



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-356142-1-1.html




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

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