单链表操作

13 篇文章 1 订阅
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <assert.h>

struct Node
{
    int data;
    struct Node *next;
}Node;

typedef struct Node list;

void InitList(list *head){
    head = (list*)malloc(sizeof(list));
    head->next = NULL;
}

void printList(list* head){
    assert(head != NULL);
    list* p = head->next;//由于头节点不保存数据,所以从下一个开始
    while(p != NULL){
        printf("Node data:%d\n", p->data);
        p = p->next;
 }
}

void creatList(list* head, int j){
    list* m = NULL;
    list* n = NULL;
    m = head;//在此插入点
    int i=0;
    for(i=0; i<j; i++){
        n = (list*)malloc(sizeof(list));
        n->data = i;//节点赋值
        m->next = n;
        m=m->nex;//下一轮节点插入位置
    }
    m->next=NULL;//最后一个节点的下一个附空值
    printf("creat list ok \n");
}

void DestroyList(list* head)
{
    list*pre = head;
    list*p = head->next;//清理前一个节点前,先保存后一个节点的地址
    
    while(p != NULL)
    {
        free(pre);
        pre = p;
        p = p->next;
    }//逐一释放空间
    free(p);//释放最后一个
    printf("destroy list ok \n");
}

//删除指定值的节点
typedef struct node {
	int data;
	node* next;
}node;

node *del(node* head, int num) {
	node*p1, *p2;
	p1 = head;
	while (num != p1->data && p1->next != NULL) {
		p2 = p1;//值等于num节点的前一个节点
		p1 = p1->next;
	}
	if (num == p1->data) {//找到了
		if( p1 == head){//在头部节点,或者在最尾部
			head = p1->next;
		}
		else {//在中间节点
			p2->next = p1->next;
		}
		free(p1);
		p1 = NULL;
	}
	else {
		cout << "can not find the node which data is num" << endl;
	}
	return head;
}

//从小到大顺序插入
node* insert(node* head, int num) {
	node *p1, *p2;
	p1 = head;
	p2 = NULL;

	node* s = (node*)malloc(sizeof(node));
	s->data = num;
	while (num > p1->data && p1->next != NULL) {
		p2 = p1;//插入节点的前一个节点
		p1 = p1->next;
	}
	if (num <= p1->data) {
		if (p1 == head) {//在头部
			s->next = head;
			head = s;
		}
		//if (p1->next == NULL) {//小于p1的不可能在尾部
		//}
		else //介于p1 和p2中间,p2 < p1
		{
			p2->next = s;
			s->next = p1;
		}
	}
	else { //num >= p1->data, num最大的一个放在最后
		p1->next = s;
		s->next = NULL;//最后一个节点为空
	}
	return head;
}

node *reverse(node *head){
     node *p1,*p2,*p3;
     if(head == NULL ||head->next ==NULL){
	    return head;
     }
     p1 = head;
     p2 = p1->next;
     while(p2){
          p3 = p2->next;//保存现场
          p2->next = p1;//反置
          p1 = p2;//后移
          p2 = p3;//后移
    }
     head->next = NULL;//反置后最后一个节点next设置
     head = p1;//指针重置
     return head;
}

int main(){
   int j = 10;
   list*head=malloc(sizeof(list));
   creatList(head, j);
   if(head == NULL) return -1;
   printList(head);
   DestroyList(head);
   return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值