【C語言】數據結構C語言版 實驗2 不帶頭結點的單鏈表


運行環境:Dev-C++

vs2013可能不能運行

首先新建一個頭文件slnklist.h

#include <stdio.h>
#include <stdlib.h> 
/**************************************/
/* 鏈表實現的頭文件,文件名slnklist.h */
/**************************************/
 typedef int datatype;
 typedef struct link_node{
   datatype info;
   struct link_node *next;
 }node;
typedef node *linklist;

/**********************************/
/*函數名稱:creatbystack()              */
/*函數功能:頭插法建立單鏈表            */
/**********************************/
linklist creatbystack()
{  linklist  head,s;
    datatype x;
    head=NULL;
    printf("請輸入若干整數序列:\n");
    scanf("%d",&x);
    while (x!=0)        /*以0結束輸入*/
    {   s=(linklist)malloc(sizeof(node));  /*生成待插入結點*/
        s->info=x;
        s->next=head;            /*將新結點插入到鏈表最前面*/
        head=s;
        scanf("%d",&x);
    }
    return head;                /*返回建立的單鏈表*/
}
/**********************************/
/*函數名稱:creatbyqueue()              */
/*函數功能:尾插法建立單鏈表            */
/**********************************/
linklist creatbyqueue()
{
    linklist head,r,s;
    datatype x;
    head=r=NULL;
    printf("請輸入若干整數序列:\n");
    scanf("%d",&x);
    while (x!=0) /*以0結束輸入*/
    {    s=(linklist)malloc(sizeof(node));
         s->info=x;
         if (head==NULL)        /*將新結點插入到鏈表最后面*/
            head=s;
         else
            r->next=s;
        r=s;
        scanf("%d",&x);
   }
    if (r)  r->next=NULL;
    return head;                    /*返回建立的單鏈表*/
}
/**********************************/
/*函數名稱:print()                      */
/*函數功能:輸出不帶頭結點的單鏈表      */
/**********************************/
void print(linklist head)
{   linklist p;
    int i=0;
    p=head;
    printf("List is:\n");
    while(p)
    {
        printf("%5d",p->info);
        p=p->next;
        i++;
        if (i%10==0) printf("\n");
    }
    printf("\n");
}
/**********************************/
/*函數名稱:delList()                  */
/*函數功能:釋放不帶頭結點的單鏈表      */
/**********************************/
void delList(linklist head)
{ linklist p=head;
  while (p)
  { head=p->next;
    free(p);
    p=head;
  }
}

1.編寫函數slnklist delx(linklist head, datatype x),刪除不帶頭結點單鏈表head中第一個值為x 的結點。 並構造測試用例進行測試。

/*編寫函數slnklist delx(linklist head, datatype x),刪除不帶頭結點單鏈表head中第一個值為x 的結點。
並構造測試用例進行測試。
*/
/**********************************/
/*文件名稱:lab2_01.c             */
/**********************************/

#include "slnklist.h"
/*請將本函數補充完整,並進行測試*/
linklist delx(linklist head,datatype x)
{
    linklist p = head,pre=NULL;//一定要初始化pre=NULL 
    while(p&&p->info!=x)
    {
        pre = p;
        p = p->next;
    }
    if(p)
    {
        if(!pre)
        {
            head = head->next;
        }
        else 
        {
            pre->next = p->next;
            free(p);
        }
    }
    return head;

}

int main()
{   datatype x;
    linklist head;
    head=creatbyqueue();        /*尾插入法建立單鏈表*/
    print(head);
    printf("請輸入要刪除的值:");
    scanf("%d",&x);
    head=delx(head,x);            /*刪除單鏈表的第一個值為x的結點*/
    print(head);
    delList(head);                /*釋放單鏈表空間*/
    return 0;
}

2.假設線性表(a1,a2,a3,…an)采用不帶頭結點的單鏈表存儲, 請設計算法函數linklist reverse1(linklist head)和 void reverse2(linklist *head)將不帶頭結點的單鏈表head就地倒置, 使表變成(an,an-1,…a3.a2,a1)。並構造測試用例進行測試。

/**********************************/
/*文件名稱:lab2_02.c                 */
/**********************************/
/*
假設線性表(a1,a2,a3,…an)采用不帶頭結點的單鏈表存儲,
請設計算法函數linklist reverse1(linklist  head)和
void reverse2(linklist *head)將不帶頭結點的單鏈表head就地倒置,
使表變成(an,an-1,…a3.a2,a1)。並構造測試用例進行測試。
*/
#include "slnklist.h"
/*請將本函數補充完整,並進行測試*/
linklist reverse1(linklist head)
{
    linklist p,q;
    p=head;
    head = NULL;
    while(p)  //核心
    {
        q = p->next;
        p->next = head;
        head=p;
        p=q;
    }
    return head;
}
void reverse2(linklist *head) //不返回值,那就從指針上下手 
{
    linklist p,q;
    p=*head;
    *head = NULL;
    while(p)
    {
        q = p->next;
        p->next = *head;
        *head=p;
        p=q;
    }
}

int main()
{   datatype x;
    linklist head;
    head=creatbystack();        /*頭插入法建立單鏈表*/
    print(head);                /*輸出原鏈表*/
    head= reverse1(head);        /*倒置單鏈表*/
    print(head);                /*輸出倒置后的鏈表*/
    reverse2(&head);            /*倒置單鏈表*/
    print(head);
    delList(head);
    return 0;
}

3.假設不帶頭結點的單鏈表head是升序排列的,設計算法函數linklist insert(linklist head,datatype x), 將值為x的結點插入到鏈表head中,並保持鏈表有序性。 分別構造插入到表頭、表中和表尾三種情況的測試用例進行測試。

/*
假設不帶頭結點的單鏈表head是升序排列的,設計算法函數linklist insert(linklist head,datatype x),
將值為x的結點插入到鏈表head中,並保持鏈表有序性。
分別構造插入到表頭、表中和表尾三種情況的測試用例進行測試。
*/
/**********************************/
/*文件名稱:lab2_03.c                 */
/**********************************/
#include "slnklist.h"
/*請將本函數補充完整,並進行測試*/
linklist insert(linklist head ,datatype x)
{
    linklist pre,p,s;
    s = (linklist)malloc(sizeof(node));
    s->info = x;
    p = head;
    pre=NULL;
    while(p&&p->infonext; 
    } 
    if(!pre)  //插在表頭 
    {
        s->next = head;
        head = s;
    }else{    //插在中間或者末尾 
        pre->next = s;   
        s->next = p;
    }

    return head;

}
int main()
{   datatype x;
    linklist head;
    printf("輸入一組升序排列的整數:\n");
    head=creatbyqueue();                /*尾插入法建立單鏈表*/
    print(head);
    printf("請輸入要插入的值:");
    scanf("%d",&x);
    head=insert(head,x);                /*將輸入的值插入到單鏈表適當位置*/
    print(head);
    delList(head);
    return 0;
}

4.編寫算法函數linklist delallx(linklist head, int x),刪除不帶頭結點單鏈表head中所有值為x的結點。

/*
編寫算法函數linklist delallx(linklist head, int x),刪除不帶頭結點單鏈表head中所有值為x的結點。
*/
/**********************************/
/*文件名稱:lab2_04.c                 */
/**********************************/
#include "slnklist.h"
/*請將本函數補充完整,並進行測試*/
linklist delallx(linklist head,int x)
{
    linklist p,t;
    while(head)//如果要刪除的是第一個 
    {
        if(head->info==x)
        {
            p=head;
            head=head->next; 
            free(p);//回收p 
        } else {
            break;
        }
    }
    if(head)//如果刪除的不是第一個 
    {
        p=head;
        while(p->next)
        {
            if(p->next->info==x)
            {
                t=p->next;
                p->next=p->next->next;
                free(t);
            } else {
                p=p->next;
            }
        }        
    }
    return head;
}
int main()
{   datatype x;
    linklist head;
    head=creatbyqueue();                /*尾插入法建立單鏈表*/
    print(head);
    printf("請輸入要刪除的值:");
    scanf("%d",&x);
    head=delallx(head,x);
    print(head);
    delList(head);
    return 0;
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM