统计带头结点的单向链表的个数并存放在形参n所指的单元中。 欢迎评论 指点。
#include <stdio.h>
#include <stdlib.h>
#define N 8
typedef struct list //定义结构体
{ int data;
struct list *next;
} SLIST; //新类型SLIST
SLIST *creatlist(int *a); //函数说明 返回值为 STIST形的指针
void outlist(SLIST *); //函数说明
void fun( SLIST *h, int *n) //定义函数 参数 指向该类型的指针h、指向整形的指针n
{ SLIST *p; // 定义指向该类型指针变量 p
*n =0;
p=h->next; // p指向首元元素
while(p) //当 p 不为空时
{ (*n)++; //*n 自加
p=p->next; // p后移
}
}
main() //主函数
{ SLIST *head; //定义该指向类型的指针 head
int a[N]={12,87,45,32,91,16,20,48}, num; //定义整形数组a、整形数num
head=creatlist(a); outlist(head); //将链表的首地址给head
fun(head, &num);
printf("\nnumber=%d\n",num);
}
SLIST *creatlist(int a[])//定义函数 建立链表 返回值为SLIST类型的地址 参数为整形数组
{ SLIST *h,*p,*q; int i; //定义 该类型的指针 h p q ,整形i
h=p=(SLIST *)malloc(sizeof(SLIST)); //动态分配 SLIST 形空间头结点 首地址给 h、p
for(i=0; i<N; i++)
{ q=(SLIST *)malloc(sizeof(SLIST)); //动态分配N个SLIST型空间
q->data=a[i]; p->next=q; p=q; //给每一个date为数组元素
}
p->next=0;
return h;
}
void outlist(SLIST *h) //定义函数 形参 指向该类型的指针
{ SLIST *p; 定义指向该类型的指针变量 p
p=h->next; //p指向 首元元素
if (p==NULL) printf("The list is NULL!\n");//判断链表是否为空 是 打印the list is null!
Else //不为空
{ printf("\nHead "); // 换行 打印 head
do
{ printf("->%d",p->data); p=p->next; } // 打印 -> date 、p后移。
while(p!=NULL); //直到 p指向尾元素的指针域
printf("->End\n"); //打印 ->end 换行
}
}
统计带头结点的单向链表的个数并存放在形参n所指的单元中。 欢迎评论 指点。相关推荐
- 数据结构例9.编写一个算法,将带头结点的单向链表 拆分成一个奇数链表和一个偶数链表,并分别输出
/* 编写一个算法,将带头结点的单向链表 拆分成一个奇数链表和一个偶数链表,并分别输出 */ # include <iostream> # include <stdlib.h> ...
- 数据结构:假设有一个带头结点的单链表L,每个结点值由单个数字、小写字母和大写字母构成。设计一个算法将其拆分成3个带头结点的单链表L1、L2和L3,L1包含L中的所有数字结点,L2包含L中的所有小写字母
假设有一个带头结点的单链表L,每个结点值由单个数字.小写字母和大写字母构成.设计一个算法将其拆分成3个带头结点的单链表L1.L2和L3,L1包含L中的所有数字结点,L2包含L中的所有小写字母结点,L3 ...
- c语言链表不带头节点的排序,不带头结点的单向链表排序——插入排序(C语言)...
LinkList* LinkListInsertSort(LinkList* pHead) { LinkList *pFirst = (LinkList *)NULL; /* 原链表剩下未排序节点的头 ...
- 不带头结点的单链表操作
不带头结点的单链表操作,包括插入.遍历.统计结点数等,要求写出数据结构算法思想及C语言实现函数 本文为博主原创文章,未经博主允许不得转载. 版权为陈博超所有,第一次于2021年06月22日发表于BLO ...
- 不带头结点的单链表的建立
建立该链表利用的是尾插法 // 创建一个单链表,没有头结点, #include <iostream> #include <ctime>using namespace std; ...
- 【C语言】数据结构C语言版 实验3 带头结点的单链表
slnklist.h #include <stdio.h> #include <stdlib.h> /************************************* ...
- python实现带头结点的单链表的就地逆置_6-1 带头结点的单链表就地逆置 (10 分)...
本题要求编写函数实现带头结点的单链线性表的就地逆置操作函数.L是一个带头结点的单链表,函数ListReverse_L(LinkList &L)要求在不新开辟节点的前提下将单链表中的元素进行逆置 ...
- 6-1 带头结点的单链表就地逆置 (10 分)
6-1 带头结点的单链表就地逆置 (10 分) 本题要求编写函数实现带头结点的单链线性表的就地逆置操作函数.L是一个带头结点的单链表,函数ListReverse_L(LinkList &L)要 ...
- 算法与数据结构之带头结点的单链表
单链表优缺点 链表是非随机存取的存储结构,和顺序表相比,链表存储结构在实现插入.删除的操作时,不需要移动大量数据元素(但不容易实现随机存取线性表的第 i 个数据元素的操作).所以,链表适用于经常需要进 ...
最新文章
- KaliLinuxNetHunter教程下载相关资源
- 济南python工资一般多少钱-济南Python+人工智能
- 深度学习,究竟该如何学?
- 【机器学习】机器学习项目流程
- C++中的构造函数小结
- 编程机器人考级证书有用吗_机器人编程有等级考试吗?
- 根据小米商城官网首页效果敲写页面
- 《MySQL数据操作与查询》- 综合项目 - 学生管理系统
- 2022年上海办理EDI增值电信经营许可证年检有哪些政策
- 深度分析AI新职位丨人工智能训练师是什么?做什么的?发展前景如何?
- 嘿!不备案不要HTTPS!小程序请求任意网站黑科技来了!
- ThinkPHP3.2.3 where注入
- groovy快速上手第2篇:数据类型篇
- 常用插件:分享12款超级好用的 Chrome 插件
- CTFshow_命令执行
- 手把手教你solidworks重力下落物体动画制作
- 如何查杀stopped进程
- 第三方支付平台:BeeCloud和Ping++对比
- 课程设计项目——网上商城
- 【数据结构】测试3 栈和队列
热门文章
- 诗与远方:无题(八十六)
- getClass().getProtectionDomain().getCodeSource().getLocation().toURI().getSchemeSpecificPart()返回内容解析
- Hexo框架+Github Page搭建博客(附下载主题、导出CSDN博客至Hexo博客)
- HDOJ-2036 求多边形面积
- 华为手机媒体音量自动静音_华为手机的音量键原来这么牛逼,这五大玩法,97.777%的人不知道...
- bootstrap和圣杯布局
- css-3秒(大概吧...)快速撸出YY游戏页面(三)
- 开源中国 Android 客户端 v2.8.4 代码开源
- Hbase 架构(未完待续)
- Elasticsearch集群监控工具bigdesk插件安装