单链表之删除头结点,查找等于定值x的结点数,单链表的逆置
/*
* @Author: 一届书生
* @Date: 2020-03-08 09:52:27
* @LastEditTime: 2020-03-08 13:58:30
*/
#include <iostream>
using namespace std;
#define elemType char typedef struct node
{
elemType data;
struct node *next;
} Lnode, *Pnode; // 带头结点-尾插法
Pnode create1()
{
Pnode head, tail, p; //头结点 尾结点 临时结点
elemType i;
head = new node; //申请头结点
tail = head; //头尾指针指向同一个结点
while ((cin >> i) && (i != '*'))
{
p = new node; //申请新结点
p->data = i; //输入结点的数据域
tail->next = p; //将新结点插入链表尾部
tail = p; //让链表的尾结点指向新结点
}
tail->next = NULL; //尾指针指向空
return head;
}; // 带头结点-头插法
Pnode create2()
{
Pnode head, p; //头结点 尾结点 临时结点
head = new node;
head->next = NULL;
elemType x;
while (cin >> x)
{
p = new node;
p->data = x;
p->next = head->next;
head->next = p;
}
return head;
}; // 删除头结点
Pnode deletHeadNode(Pnode &a)
{
if (a == NULL)
{
cout << "空表" << endl;
return a;
}
Pnode t = a;
a = a->next;
t->next = NULL;
free(t);
return a;
} // 添加头结点
Pnode addHeadNode(Pnode &p){
Pnode head;
head=new node;
head->next=p;
return head;
} // 统计出带头单链表中结点的值等于给定值X的结点数
int getNumX(Pnode a,elemType x){
int cnt=0;
a=a->next;
while(a){
if(a->data==x)
cnt++;
a=a->next;
}
return cnt;
} // 单链表逆置 头插法
void reverse(Pnode &head) {
Pnode t,p,q=head->next;
p=q->next;
q->next=NULL;
while(p){
t=p->next;
p->next=q;
q=p;
p=t;
}
head->next=q;
} // 带头结点遍历输出
void display(Pnode head){ //输出链表中的数据
Pnode p;
p = head->next;
while (p != NULL){
cout<< p->data;
if (p->next != NULL)
cout<<' ';
p = p->next; //p指向下一个结点
}
cout<<endl;
} int main()
{
// 样例:123456789111
Pnode p;
p = create1();
display(p); // 带头结点遍历输出
// 输出:1 2 3 4 5 6 7 8 9 1 1 1 p = deletHeadNode(p);
display(p); // 查看是否已经删除了头结点,若成功删除的话,应该从第二个结点开始输出
// 输出:2 3 4 5 6 7 8 9 1 1 1 p=addHeadNode(p);
display(p); //加上头结点后,再遍历一遍看看结果
// 输出:1 2 3 4 5 6 7 8 9 1 1 1 elemType t='1';
cout<<getNumX(p,t)<<endl; //单链表:123456789111 输出:4 reverse(p);
display(p); // 输出:1 1 1 9 8 7 6 5 4 3 2 1 return 0;
}
单链表之删除头结点,查找等于定值x的结点数,单链表的逆置的更多相关文章
- 单链表在不知头结点的情况下对第i个元素的删除
一.首先,看看单链表中第i个元素的删除: Status ListDelete_L (LinkList &L,int i,ElemType &e){ //在带头结点的单链表L中,删除第i ...
- 建立链表的虚拟头结点 203 Remove Linked List Element,82,147,148,237
该逻辑对于删除第一个元素不适用. 这样的代码不优美 /** * Definition for singly-linked list. * struct ListNode { * int val; * ...
- [Leetcode] Remove duplicate from sorted list ii 从已排序的链表中删除重复结点
Given a sorted linked list, delete all nodes that have duplicate numbers, leaving only distinct numb ...
- 在单链表和双链表中删除倒数第k个结点
题目: 分别实现两个函数,一个可以删除单链表中倒数第K个节点,另一个可以删除双链表中倒数第K个节点. 要求: 如果链表长度为N,时间复杂度达到O(N),额外空间复杂度达到O(1). 解答: 让链表从头 ...
- 《Java数据结构与算法》笔记-CH5-链表-2单链表,增加根据关键字查找和删除
/** * Link节点 有数据项和next指向下一个Link引用 */ class Link { private int iData;// 数据 private double dData;// 数据 ...
- 剑指offer56:删除链表中重复的结点,排序的链表中,删除重复的结点不保留,返回链表头指针。 例如,链表1->2->3->3->4->4->5 处理后为 1->2->5
1 题目描述 在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针. 例如,链表1->2->3->3->4->4->5 处 ...
- 左神算法书籍《程序员代码面试指南》——2_02在单链表和双链表中删除倒数第k个字节
[题目]分别实现两个函数,一个可以删除单链表中倒数第K个节点,另一个可以删除双链表中倒数第K个节点.[要求]如果链表长度为N,时间复杂度达到O(N),额外空间复杂度达到O(1).[题解]从头遍历链表, ...
- 《剑指offer》第十八题(删除链表中重复的结点)
// 面试题18(二):删除链表中重复的结点 // 题目:在一个排序的链表中,如何删除重复的结点?例如,在图3.4(a)中重复 // 结点被删除之后,链表如图3.4(b)所示. #include &l ...
- 《程序员代码面试指南》第二章 链表问题 在单链表和双链表中删除倒数第K个节点
题目 在单链表和双链表中删除倒数第K个节点 java代码 /** * @Description:在单链表和双链表中删除倒数第K个节点 * @Author: lizhouwei * @CreateDat ...
- 删除链表中重复的结点——牛客剑指offer
题目描述: 在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针. 例如,链表1->2->3->3->4->4->5 处理 ...
随机推荐
- [VueJsDev] 基础知识 - CommonJs VS ES Module
[VueJsDev] 目录列表 https://www.cnblogs.com/pengchenggang/p/17037320.html CommonJs VS ES Module ::: deta ...
- npm-links - 查看项目依赖包 - vscode 插件
npm-links 依赖包相关快捷链接
- WPF之命令
目录 命令系统的基本元素 基本元素之间的关系 小试命令 WPF的命令库 命令参数 命令与Binding的结合 近观命令 ICommand接口与RoutedCommand 自定义Command 定义命令 ...
- ACER 宏碁 笔记本无法进入 grub 引导 + 安全启动失败(security boot fail ) 解决办法
主要介绍让BIOS首先引导grub的方法 加一点:添加完新的启动选项以后,如果看不到添加的启动项,就先保存重启,再进 BIOS 就可以看到了 我是宏碁的笔记本,装了双系统.之前无意间进了一次 BIOS ...
- python文件获取并读取固定长度数据实例解析
一 概念 1 file 操作: 文件操作一般有open,write,read,close几种,这里重点是read固定长度数据. read() 用于从文件读取指定的字节数,如果未给定或为负则读取所有. ...
- 关于初始化page入参的设计思路
最近在重构老的代码,在写的过程中发现之前的逻辑如果遇到没有入参pageNo会Npe,于是乎我想找找公司项目有啥方式处理page入参的有两种如下 使用三元表达式直接判断是否null,然后赋值 使用map ...
- Eclipse之各个版本的区别
经常用到的是前五个版本: Eclipse IDE for Java EE Developers:是为J2EE开发的版本: Eclipse Classic:是Eclipse的经典版本,没有安装任何插件, ...
- 10_PCM转WAV
播放器是无法直接播放PCM的,因为播放器并不知道PCM的采样率.声道数.位深度等参数.当PCM转成某种特定的音频文件格式后(比如转成WAV),就能够被播放器识别播放了. 本文通过2种方式(命令行.编程 ...
- kali 2018.2镜像安装
本文链接来源 Kali Linux 前身是著名渗透测试系统BackTrack ,是一个基于 Debian 的 Linux 发行版,包含很多安全和取证方面的相关工具.此次通过VMware虚拟机安装201 ...
- API接口开发规范
API接口是不同软件系统之间进行通信的重要方式,良好的API接口设计规范可以提高系统的可维护性.可扩展性和易用性.本文介绍了一套详细的API接口开发规范,包括命名规范.请求和响应规范.安全规范等内容, ...