链表的简单的实现

#include <stdio.h>
#include <stdlib.h>
#include <time.h>


typedef struct LinkNode {
    int data;
    struct LinkNode *next; 
} LinkNode;


typedef struct LinkList {
    LinkNode *head;
    int n;
} LinkList;


LinkList *init() {
    LinkList *p = (LinkList *)malloc(sizeof(LinkList));
    p->head = NULL;
    p->n = 0;
    return p;
}


LinkNode *getNewNode(int data) {
    LinkNode *p = (LinkNode *)malloc(sizeof(LinkNode));
    p->data = data;
    p->next = NULL;
    return p;



int insert(LinkList *l, int data, int ind) {
    if (ind < 0 || ind > l->n) return 0;
    LinkNode ret, *p;
    ret.next = l->head;
    p = &ret;
    while (p && ind--) {
        p = p->next;
    }
    LinkNode *new_node = getNewNode(data);
    new_node->next = p->next;
    p->next = new_node;
    l->head = ret.next;
    l->n += 1;
    return 1;
}


void clear(LinkList *l) {
    LinkNode *head = l->head;
    while (head) {
        LinkNode *next = head->next;
        free(head);
        head = next;
    }
    free(l);
    return ;
}


void output(LinkList *l) {
    LinkNode *head = l->head;
    while (head) {
        printf("%d ->", head->data);
        head = head->next;
    }
    printf("null\n");
}


int main() {
    LinkList *l = init();
    srand(time(0));
    for (int i = 0; i < 10; i++) {
        int data = rand() % 100, ind = rand() % (i + 1);
        printf("%d : insert(%d, %d) = ", i, data, ind);
        fflush(stdout);
        printf("%d : ", insert(l, data, ind));
        output(l);
    }
    clear(l);
    return 0;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值