g
y
7
7
7
7

单链表之删除头结点,查找等于定值x的结点数,单链表的逆置

/*
 * @Author: 一届书生
 * @Date: 2020-03-08 09:52:27
 * @LastEditTime: 2020-03-08 13:58:30
 */
#include <iostream>
using namespace std;
#define elemType char

typedef struct node
{
    elemType data;
    struct node *next;
} Lnode, *Pnode;

// 带头结点-尾插法
Pnode create1()
{
    Pnode head, tail, p; //头结点 尾结点  临时结点
    elemType i;
    head = new node; //申请头结点
    tail = head;     //头尾指针指向同一个结点
    while ((cin >> i) && (i != '*'))
    {
        p = new node;   //申请新结点
        p->data = i;    //输入结点的数据域
        tail->next = p; //将新结点插入链表尾部
        tail = p;       //让链表的尾结点指向新结点
    }
    tail->next = NULL; //尾指针指向空
    return head;
};

// 带头结点-头插法
Pnode create2()
{
    Pnode head, p; //头结点 尾结点  临时结点
    head = new node;
    head->next = NULL;
    elemType x;
    while (cin >> x)
    {
        p = new node;
        p->data = x;
        p->next = head->next;
        head->next = p;
    }
    return head;
};

// 删除头结点
Pnode deletHeadNode(Pnode &a)
{
    if (a == NULL)
    {
        cout << "空表" << endl;
        return a;
    }
    Pnode t = a;
    a = a->next;
    t->next = NULL;
    free(t);
    return a;
}

// 添加头结点
Pnode addHeadNode(Pnode &p){
    Pnode head;
    head=new node;
    head->next=p;
    return head;
}

// 统计出带头单链表中结点的值等于给定值X的结点数
int getNumX(Pnode a,elemType x){
    int cnt=0;
    a=a->next;
    while(a){
        if(a->data==x)
            cnt++;
        a=a->next;
    }
    return cnt;
}

// 单链表逆置     头插法
void reverse(Pnode &head) {
    Pnode t,p,q=head->next;     
    p=q->next;
    q->next=NULL;
    while(p){
        t=p->next;
        p->next=q;
        q=p;
        p=t;
    }
    head->next=q;
}

// 带头结点遍历输出
void display(Pnode head){   //输出链表中的数据
    Pnode p;
    p = head->next;
    while (p != NULL){
        cout<< p->data;
        if (p->next != NULL)
        cout<<' ';
        p = p->next; //p指向下一个结点
    }
    cout<<endl;
}

int main()
{
    // 样例:123456789111
    Pnode p;
    p = create1();
    display(p); // 带头结点遍历输出 
                // 输出:1 2 3 4 5 6 7 8 9 1 1 1

    p = deletHeadNode(p);
    display(p); // 查看是否已经删除了头结点,若成功删除的话,应该从第二个结点开始输出
                // 输出:2 3 4 5 6 7 8 9 1 1 1

    p=addHeadNode(p);
    display(p); //加上头结点后,再遍历一遍看看结果
                // 输出:1 2 3 4 5 6 7 8 9 1 1 1

    elemType t='1';
    cout<<getNumX(p,t)<<endl;     //单链表:123456789111   输出:4

    reverse(p);
    display(p);     // 输出:1 1 1 9 8 7 6 5 4 3 2 1

    return 0;
}

  

posted @ 2020-03-08 14:05  gy77  阅读(411)  评论(0编辑  收藏  举报