linux下练习 c++ 链表操作

简介: #include using namespace std; typedef int T; class List { struct Node { T data; Node * next; Node(const T...
#include <iostream>
using namespace std;
typedef int T;
class List
{
	struct Node
	{
		T data;
		Node * next;
		Node(const T&d=T()):data(d),next(0){}
	};
	Node * head;
	public:
		List():head(NULL)
		{
			cout<<"…list初始化完成…\n";
		}
		void push_front(const T&d)//前插法
			{
				Node * p=new Node(d);
				p->next=head;
				head=p;
			}
		void push_behand(const T&d)//尾插法
			{
				Node *ph=head;
				while(ph->next!=NULL) ph=ph->next;
				Node * p=new Node(d);
				ph->next=p;
			}
		void insert(const T&d,int pos)//任意位置插入
			{
				Node * p=new Node(d);
				Node *& pn=getptr(pos);
				p->next=pn;
				pn=p;
				/*
				if(pos<=0)
				{
				    p->next=head;
				    head=p;
				}
				else
				{
					Node * ph=head;
					while(pos-->1 && ph->next !=NULL)
					{
						ph=ph->next;
					}
					p->next=ph->next;
					ph->next=p;
					
				}
				*/
			}
		void remove(int pos)
		{
			if(pos<0) return ;
			Node *& pn=getptr(pos);
			Node *p=pn;
			pn=pn->next;
			delete p;
		}
		Node *& getptr(int pos)
		{
			
			if(pos<=0) return head;
			Node * p =head;
			while(pos-->1 && p->next !=NULL)
				p=p->next;
			return (*p).next; 
		}
		void travel()const//遍历
		{
			Node * p=head;
			while(p!=NULL)
			{
				cout<<p->data<<' ';
				p=p->next;
			}
			cout<<endl;
		}
		void clear()//清空内存
		{
			while(head != NULL)
			{
				Node *p=head->next;
				delete head;
				head=p;
			}
		}
		~List()
		{
			clear();
			cout<<"…内存释放完成…\n";
		}
};
int main()
{
	List l;
	l.push_front(5);
	l.push_front(4);
	l.push_front(7);
	l.push_front(6);
	l.push_behand(45);
	l.push_behand(48);
	l.insert(100,0);//小于0位置就插入到最前
	l.insert(99,6);//插入到指定位置
	l.insert(991,100);//大于最后位置就插入到最后
	l.remove(1);
	l.remove(0);
	l.travel();
	return 0;
}


 

list.cpp

 

g++ -o list.out list.cpp

./list.out

 

相关文章
|
4月前
|
网络协议 安全 Linux
Linux C/C++之IO多路复用(select)
这篇文章主要介绍了TCP的三次握手和四次挥手过程,TCP与UDP的区别,以及如何使用select函数实现IO多路复用,包括服务器监听多个客户端连接和简单聊天室场景的应用示例。
127 0
|
4月前
|
存储 Linux C语言
Linux C/C++之IO多路复用(aio)
这篇文章介绍了Linux中IO多路复用技术epoll和异步IO技术aio的区别、执行过程、编程模型以及具体的编程实现方式。
181 1
Linux C/C++之IO多路复用(aio)
|
17天前
|
消息中间件 Linux C++
c++ linux通过实现独立进程之间的通信和传递字符串 demo
的进程间通信机制,适用于父子进程之间的数据传输。希望本文能帮助您更好地理解和应用Linux管道,提升开发效率。 在实际开发中,除了管道,还可以根据具体需求选择消息队列、共享内存、套接字等其他进程间通信方
53 16
|
4月前
|
资源调度 Linux 调度
Linux c/c++之进程基础
这篇文章主要介绍了Linux下C/C++进程的基本概念、组成、模式、运行和状态,以及如何使用系统调用创建和管理进程。
71 0
|
1月前
|
机器学习/深度学习 存储 C++
【C++数据结构——线性表】单链表的基本运算(头歌实践教学平台习题)【合集】
本内容介绍了单链表的基本运算任务,涵盖线性表的基本概念、初始化、销毁、判定是否为空表、求长度、输出、求元素值、按元素值查找、插入和删除数据元素等操作。通过C++代码示例详细解释了顺序表和链表的实现方法,并提供了测试说明、通 - **任务描述**:实现单链表的基本运算。 - **相关知识**:包括线性表的概念、初始化、销毁、判断空表、求长度、输出、求元素值、查找、插入和删除等操作。 - **测试说明**:平台会对你编写的代码进行测试,提供测试输入和预期输出。 - **通关代码**:给出了完整的C++代码实现。 - **测试结果**:展示了测试通过后的预期输出结果。 开始你的任务吧,祝你成功!
46 5
|
4月前
|
Ubuntu Linux 编译器
Linux/Ubuntu下使用VS Code配置C/C++项目环境调用OpenCV
通过以上步骤,您已经成功在Ubuntu系统下的VS Code中配置了C/C++项目环境,并能够调用OpenCV库进行开发。请确保每一步都按照您的系统实际情况进行适当调整。
1053 3
|
4月前
|
资源调度 Linux 调度
Linux C/C++之线程基础
这篇文章详细介绍了Linux下C/C++线程的基本概念、创建和管理线程的方法,以及线程同步的各种机制,并通过实例代码展示了线程同步技术的应用。
68 0
Linux C/C++之线程基础
|
4月前
|
Linux C++
Linux C/C++之IO多路复用(poll,epoll)
这篇文章详细介绍了Linux下C/C++编程中IO多路复用的两种机制:poll和epoll,包括它们的比较、编程模型、函数原型以及如何使用这些机制实现服务器端和客户端之间的多个连接。
105 0
Linux C/C++之IO多路复用(poll,epoll)
|
4月前
|
网络协议 Linux 网络性能优化
Linux C/C++之TCP / UDP通信
这篇文章详细介绍了Linux下C/C++语言实现TCP和UDP通信的方法,包括网络基础、通信模型、编程示例以及TCP和UDP的优缺点比较。
108 0
Linux C/C++之TCP / UDP通信
|
4月前
|
消息中间件 Linux API
Linux c/c++之IPC进程间通信
这篇文章详细介绍了Linux下C/C++进程间通信(IPC)的三种主要技术:共享内存、消息队列和信号量,包括它们的编程模型、API函数原型、优势与缺点,并通过示例代码展示了它们的创建、使用和管理方法。
73 0
Linux c/c++之IPC进程间通信