11.30学习打卡

学习时机

19:00——22:00链表的学习

学习时间3小时,尝试链表的使用与用法.

#include <stdio.h>
#include <stdlib.h>
struct node {
	int date;//数据域
	struct node* next;//指针域
};
struct node* createList() {
	struct node*headnode = (struct node*)malloc(sizeof(struct node));
	headnode->date = 1;
	headnode->next = NULL;
	return headnode;
};
//创建节点
struct node* createnode(int date) {
	struct node* newnode = (struct node*)malloc(sizeof(struct node));//headnode为结构体变量,使用前需要初始化
	newnode->date = date;
	newnode->next = NULL;
	return newnode;
};
void printflist(struct node* headnode) {
	struct node* pmove = headnode->next;
	while (pmove) {
		printf("%d ", pmove->date);
		pmove = pmove->next;
	}
	printf("\n");
}
void insertnodebyhead(struct node* headnode, int date) {//链表--头插
	struct node* newnode = createnode(date);
	newnode->next = headnode->next;
	headnode->next = newnode;
}
void insertnodenexthead(struct node* headnode,int date){//链表--尾插
	struct node* newnode =createnode(date);
	node *p=headnode;
	while(p->next!=NULL){
	p=p->next;
	}
	p->next=newnode;
	p=newnode;
}

void deletenodebyappoin(struct node* headnode, int posdate) {//链表的删除
	struct node*posnode = headnode->next;
	struct node* posnodefront = headnode;
	if (posnode == NULL) {
		printf("000");
	} else {
		while (posnode->date != posdate) {
			posnodefront = posnode;
			posnode = posnodefront->next;
			if (posnode == NULL) {
				printf("没有找到");
				break;
			}
		}
		posnodefront->next = posnode->next;
		free(posnode);
	}
}
int main() {
	struct node* list = createList();
	insertnodebyhead(list, 1);
	insertnodebyhead(list, 5);
	insertnodebyhead(list, 3);
	insertnodenexthead(list,9);
	insertnodenexthead(list,10);
	printflist(list);
	deletenodebyappoin(list, 5);
	printflist(list);
	system("pause");
	return 0;
	
}

通过以上代码实现了链表的头插与尾插,链表数据删除,

 效果图

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值