如何统计单链表中数据的个数C语言函数代码

时间: 2023-04-09 20:01:22 浏览: 85
可以使用以下代码来统计单链表中数据的个数: ``` int count(struct Node* head) { int count = 0; struct Node* current = head; while (current != NULL) { count++; current = current->next; } return count; } ``` 其中,`head` 是指向链表头节点的指针,`Node` 是链表节点的结构体,包含一个数据成员和一个指向下一个节点的指针。`count` 函数使用一个循环遍历链表,每遍历一个节点就将计数器加 1,直到遍历完整个链表。最后返回计数器的值,即链表中数据的个数。
相关问题

单链表中查找相同元素的个数 写一个C语言代码

以下是一个用C语言实现单链表中查找相同元素的个数的示例代码: ```c #include <stdio.h> #include <stdlib.h> typedef struct ListNode { int val; struct ListNode* next; } ListNode; int* countSameNodes(ListNode* head, int* returnSize) { int* count_dict = (int*)malloc(1000 * sizeof(int)); for (int i = 0; i < 1000; i++) { count_dict[i] = 0; } ListNode* cur = head; while (cur != NULL) { count_dict[cur->val]++; cur = cur->next; } *returnSize = 1000; return count_dict; } int main() { // 创建单链表 ListNode* node1 = (ListNode*)malloc(sizeof(ListNode)); node1->val = 1; ListNode* node2 = (ListNode*)malloc(sizeof(ListNode)); node2->val = 2; ListNode* node3 = (ListNode*)malloc(sizeof(ListNode)); node3->val = 3; ListNode* node4 = (ListNode*)malloc(sizeof(ListNode)); node4->val = 2; ListNode* node5 = (ListNode*)malloc(sizeof(ListNode)); node5->val = 1; node1->next = node2; node2->next = node3; node3->next = node4; node4->next = node5; node5->next = NULL; // 查找相同元素个数 int size; int* count = countSameNodes(node1, &size); for (int i = 0; i < size; i++) { if (count[i] > 0) { printf("元素 %d 出现了 %d 次\n", i, count[i]); } } // 释放内存 free(node1); free(node2); free(node3); free(node4); free(node5); free(count); return 0; } ``` 在这个示例代码中,我们定义了一个结构体ListNode来表示单链表的节点。countSameNodes函数接受单链表的头结点和一个指向整型数组大小的指针作为参数,返回一个指向整型数组的指针,该数组存储了每个元素出现的次数。在函数中,我们首先使用malloc函数动态分配了一个大小为1000的整型数组,并将其中的所有元素初始化为0。然后遍历整个链表,对于每个节点,将其对应的计数器加1。最后返回整型数组指针和数组大小。在主函数中,我们创建了一个包含5个节点的单链表,并调用countSameNodes函数查找相同元素的个数。最后释放了所有节点和动态分配的内存。

求单链表长度代码C语言

下面是一个单链表长度的C语言示例代码: ```c /* 单链表节点结构体定义 */ struct ListNode { int val; struct ListNode *next; }; int getLinkedListLength(struct ListNode* head) { int count = 0; struct ListNode* curr = head; while (curr != NULL) { count++; curr = curr->next; } return count; } ``` 该函数接收单链表的头节点 `head`,并返回链表的长度。函数内部通过遍历链表,使用一个计数器变量 `count` 统计链表中节点的个数,最后返回计数器的值即可。

相关推荐

最新推荐

recommend-type

C语言统计一篇英文短文中单词的个数实例代码

本文通过实例代码给大家介绍的C语言统计一篇英文短文中单词的个数,代码简单易懂,非常不错,具有参考借鉴价值,需要的朋友参考下吧
recommend-type

C语言统计一串字符中空格键、Tab键、回车键、字母、数字及其他字符的个数(Ctrl+Z终止输入)

主要介绍了C语言统计一串字符中空格键、Tab键、回车键、字母、数字及其他字符的个数(Ctrl+Z终止输入) ,需要的朋友可以参考下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用 Python 画一个可以动的爱心

好的,我可以帮助您使用Python来绘制一个动态的爱心。您可以使用turtle库来实现。以下是实现代码: ```python import turtle import math # 设置画布和画笔 canvas = turtle.Screen() canvas.bgcolor("black") pencil = turtle.Turtle() pencil.speed(0) pencil.color("red", "pink") pencil.pensize(3) # 定义爱心函数 def draw_love(heart_size, x_offset=0, y_offset=0):
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

实现实时监控告警系统:Kafka与Grafana整合

![实现实时监控告警系统:Kafka与Grafana整合](https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X2pwZy9BVldpY3ladXVDbEZpY1pLWmw2bUVaWXFUcEdLT1VDdkxRSmQxZXB5R1lxaWNlUjA2c0hFek5Qc3FyRktudFF1VDMxQVl3QTRXV2lhSWFRMEFRc0I1cW1ZOGcvNjQw?x-oss-process=image/format,png) # 1.1 Kafka集群架构 Kafka集群由多个称为代理的服务器组成,这
recommend-type

已知n个人(以编号0,1,2,3...n-1分别表示)围坐在一张圆桌周围。从编号为0的人开始报数1,数到m的那个人出列;他的下一个人又从1开始报数,数到m+1的那个人又出列(每次报数值加1);依此规律重复下去,直到圆桌周围的人全部出列。用递归方法解决

这个问题可以使用递归方法解决。下面是一个思路: 1. 定义一个函数,接收三个参数:n、m、i,表示还剩下n个人,每次数到m时出列,当前报数的人是i; 2. 如果n=1,返回i,即最后留下的那个人的编号; 3. 否则,计算出下一个出列的人的编号j,通过递归调用函数解决n-1个人的问题,其结果为k; 4. 如果k < j,即当前i之后出列的人的编号为k,需要将k转换为在i之前出列的编号,返回值为 k+(n-1); 5. 如果k>=j,即当前i之后出列的人的编号为k,返回值为 k-(j-1); 下面是对应的Python代码: ```python def josephus(n, m, i):