判断链表是否为空并且求链表长度

#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
struct node
{
int data;
struct node *pnext;
};
struct node *creat_list();
void traverse_list(struct node *phead);
bool is_empty(struct node *phead);
int lenght_list(struct node *phead);
int main()
{
struct node *phead;
phead=creat_list();
traverse_list(phead);
if(is_empty(phead))
printf("链表不为空!\n");
else
printf("链表为空!\n");
int len=lenght_list(phead);
printf("链表的节点个数为:%d\n",len);
return 0;
}
//创建链表函数
struct node *creat_list()
{
struct node *phead,*ptail,*pnew;
phead=(struct node *)malloc(sizeof(struct node));
ptail=phead;
ptail->pnext=NULL;
if(NULL==phead)
{
printf("分配内存失败,终止程序!\n");
exit(0);
}
int len;//表示要创建的节点数
int val;
printf("请输入要创建的节点数:");
scanf("%d",&len); 
for(int i=0;i<len;i++)
{
printf("请输入%d个节点的数据:",i+1);
scanf("%d",&val);
pnew=(struct node *)malloc(sizeof(struct node));
if(NULL==pnew)
{
printf("分配内存失败,终止程序!\n");
exit(0);
}
pnew->data=val;
ptail->pnext=pnew;
pnew->pnext=NULL;
ptail=pnew;
return phead;
}
//遍历链表函数
void traverse_list(struct node *phead)
{
struct node *p=phead->pnext;
while(p!=NULL)
{
printf("%d ",p->data);
p=p->pnext;
printf("\n");
return ;
//判断链表是否为空函数 
bool is_empty(struct node *phead)
{
if(phead->pnext!=NULL)
return true;
else
return false;
}
int lenght_list(struct node *phead)
{
struct node *p=phead->pnext;
int len=0;
while(p!=NULL)
{
len++;
p=p->pnext;
}
return len;
}

转载于:https://my.oschina.net/u/553254/blog/71989

以下是用C语言实现单链表的基本操作代码: ```c #include <stdio.h> #include <stdlib.h> //定义链表节点结构体 typedef struct node { int data; struct node *next; } Node; //创建链表 Node* createList() { Node *head = (Node*)malloc(sizeof(Node)); head->next = NULL; return head; } //插入节点 void insertNode(Node *head, int data) { Node *p = head; while(p->next != NULL) { p = p->next; } Node *newNode = (Node*)malloc(sizeof(Node)); newNode->data = data; newNode->next = NULL; p->next = newNode; } //删除节点 void deleteNode(Node *head, int data) { Node *p = head, *q = head->next; while(q != NULL && q->data != data) { p = q; q = q->next; } if(q != NULL) { p->next = q->next; free(q); } } //判断链表是否为空 int isEmpty(Node *head) { return head->next == NULL; } //输出链表长度 int length(Node *head) { int len = 0; Node *p = head->next; while(p != NULL) { len++; p = p->next; } return len; } //输出链表 void printList(Node *head) { Node *p = head->next; while(p != NULL) { printf("%d ", p->data); p = p->next; } printf("\n"); } int main() { Node *head = createList(); printf("链表是否为空:%d\n", isEmpty(head)); printf("链表长度:%d\n", length(head)); insertNode(head, 1); insertNode(head, 2); insertNode(head, 3); printf("插入节点后的链表:"); printList(head); printf("链表是否为空:%d\n", isEmpty(head)); printf("链表长度:%d\n", length(head)); deleteNode(head, 2); printf("删除节点后的链表:"); printList(head); printf("链表是否为空:%d\n", isEmpty(head)); printf("链表长度:%d\n", length(head)); return 0; } ``` 输出结果: ``` 链表是否为空:1 链表长度:0 插入节点后的链表:1 2 3 链表是否为空:0 链表长度:3 删除节点后的链表:1 3 链表是否为空:0 链表长度:2 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值