注册 登录
编程论坛 数据结构与算法

如何建立单链表

瑶瑶1122333 发布于 2011-11-24 20:19, 778 次点击
如何建立单链表
3 回复
#2
q9820043422011-11-24 22:47
我不知道你看过数据结构这本书没,代码给你附上,是算法,不是完整的
程序代码:
/*结构定义*/
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);

}

多看课本,希望你能学好
#3
绿茶盖儿2011-11-27 12:05
还是好好看书吧
#4
jht7274152011-11-27 21:32
有两种方法 尾插法和头插法
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;
}
}
 
1