找回密码
 中文实名注册
查看: 275|回复: 1

c++链表学习(全操作)——指针

[复制链接]

702

主题

1094

帖子

2万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
22159
发表于 2022-9-13 12:55:21 | 显示全部楼层 |阅读模式
[C++] 纯文本查看 复制代码
#include <iostream>
#include <cstring>
using namespace std;
struct link {
        int elem;
        struct link* next;
};
//
link* initLink();//初始化
link* insertElem(link* p, int elem, int add);//插入
link* delElem(link* p, int add);//删
int selectElem(link* p, int elem);//选
link* amendElem(link* p, int add, int newElem);//改
void display(link* p);//输出

int main() {
        link* p = initLink();
        display(p);//1234

        p = insertElem(p, 5, 4);
        display(p);//12354

        p = delElem(p, 3);
        display(p);//1254

        int address = selectElem(p, 2);
        if (address == -1) {
                cout << "没有该元素"<<endl;
        }
        else {
                cout << "元素2 的位置为 " << address<<endl;
        }
        cout << "更改第3 的位置的数据为7:" << endl;
        p = amendElem(p, 3, 7);
        display(p);
        return 0;
}

link* initLink() {
        link* p = (link*)new link;//给p分配了一个link类型
        link* temp = p;//temp同p
        for (int i = 1; i < 5; i++) {
                link* a = (link*)new link;//给a分配了一个link类型
                a->elem = i;//a中的elem元素的调用
                a->next = NULL;//a中的next元素的调用
                temp->next = a;//temp的next是a
                temp = temp->next;//temp变成a
        }
        return p;
}
link* insertElem(link* p, int elem, int add) {
        link* temp = p;
        for (int i = 1; i < add; i++) {
                if (temp == NULL) {
                        cout << "插入位置无效" << endl;
                        return p;
                }
                temp = temp->next;
        }
        //指针移动
        link* c = (link*) new link;
        c->elem = elem;
        c->next = temp->next;
        temp->next = c;
        return p;
}
link* delElem(link* p, int add) {
        link* temp = p;
        for (int i = 1; i < add; i++) {
                temp = temp->next;
        }
        link* del = temp->next;
        temp->next = temp->next->next;
        delete del;
        return p;
}
int selectElem(link* p, int elem) {
        link* t = p;
        int i = 1;
        while (t->next) {
                t = t->next;
                if (t->elem == elem) {
                        return i;
                }
                i++;
        }
        return -1;
}
link* amendElem(link* p, int add, int newElem) {
        link* temp = p; temp = temp->next;

        for (int i = 1; i < add; i++) {
                temp = temp->next;
        }
        temp->elem = newElem;
        return p;
}

void display(link* p) {
        link* temp = p;

        while (temp->next) {
                temp = temp->next; cout << temp->elem;
        }
        cout << endl;
}

回复

使用道具 举报

702

主题

1094

帖子

2万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
22159
 楼主| 发表于 2022-9-13 15:20:45 | 显示全部楼层
[C++] 纯文本查看 复制代码
#include<iostream>
using namespace std;
#define ElemType int
 
//************************单链表的存储结构********************
typedef struct LNode
{
	ElemType data;//结点的数据域
	struct LNode* next;//结点的指针域
}LNode, * LinkList;//LinkList为指向结构体LNode的指针类型
 
//***********************单链表的基本操作函数******************
 
//单链表的初始化
void InitList(LinkList& L)
{
	//构造一个空的单链表
	L = new LNode;
	L->next = NULL;
}
//单链表的创建
void CreateList_H(LinkList& L)//前插法创建单链表
{
	//创建一个长度为n的单链表L,逆序位插入
	int n;
	LNode* p;
	cout << "请输入创建的单链表长度:" << endl;
	cin >> n;
	for (int i = 0; i < n; i++)
	{
		p = new LNode;
		cout << "请输入插入的第" << i + 1 << "个数据值" << endl;
		cin >> p->data;
		p->next = L->next;
		L->next = p;
	}
}
 
void CreateList_R(LinkList& L)//后插法创建单链表
{
	//创建一个长度为n的单链表L,正序位插入
	int n;
	LNode* p, * r;
	r = L;//尾指针r指向头结点
	cout << "请输入创建的单链表长度:" << endl;
	cin >> n;
	for (int i = 0; i < n; i++)
	{
		p = new LNode;
		cout << "请输入插入的第" << i + 1 << "个数据值" << endl;
		cin >> p->data;
		p->next = NULL;
		r->next = p;
		r = p;
	}
}
 
//单链表的插入
bool ListInsert(LinkList& L, int i, ElemType e)
{
	//在带头结点的单链表L的第i个结点前插入新结点
	LinkList p = L;
	LNode* s;
	int j = 0;
	while (p && j < i - 1)//p指向第i-1个结点
	{
		p = p->next;
		j++;
	}
	if (!p || i < 1)//i大于表长+1或小于1,插入位置不合法
	{
		return false;
	}
	s = new LNode;
	s->data = e;
	s->next = p->next;
	p->next = s;
	return true;
}
 
//单链表的删除
bool ListDelete(LinkList& L, int i, ElemType& e)
{
	//将单链表的第i个结点删除
	LinkList p = L;
	LNode* q;
	int j = 0;
	while (p->next && j < i - 1)//p指向第i-1个结点
	{
		p = p->next;
		j++;
	}
	if (!(p->next) || i < 1)//i大于表长或小于1,删除位置不合法
	{
		return false;
	}
	q = p->next;//临时保存被删结点的地址以备释放
	p->next = q->next;
	e = q->data;//保存被删结点的数据
	delete q;//释放被删结点的空间
	return true;
}
 
//单链表的取值
bool GetElem(LinkList L, int i, ElemType& e)
{
	//获取单链表中第i个结点的数据
	LinkList p = L;
	int j = 0;
	while (p->next && j < i - 1)//p指向第i-1个结点
	{
		p = p->next;
		j++;
	}
	if (!(p->next) || i < 1)//i大于表长或小于1,第i个结点不存在
	{
		return false;
	}
	e = p->next->data;//获取第i个结点的数据
	return true;
}
 
//单链表的查找
bool LocateElem(LinkList L, LNode*& p, ElemType e)
{
	//在单链表中查找第一个数据为e的结点
	p = L->next;//p指向首元结点
	while (p && p->data != e)
	{
		p = p->next;
	}
	if (p)
	{
		return true;
	}
	return false;
}
 
//*********************************单链表的基本功能函数******************************
 
//1、插入
void ListInsert(LinkList& L)
{
 
	ElemType e;
	int i;
	bool flag;
	cout << "请输入要插入的数据:" << endl;
	cin >> e;
	cout << "请输入要插入的位置:" << endl;
	cin >> i;
	flag = ListInsert(L, i, e);
	if (flag)
		cout << "插入成功!" << endl;
	else
		cout << "位置不对,插入失败!" << endl;
}
 
//2、删除
void ListDelete(LinkList& L)
{
	ElemType e;
	int i;
	bool flag;
	cout << "请输入要删除数据的位置:" << endl;
	cin >> i;
	flag = ListDelete(L, i, e);
	if (flag)
		cout << "删除成功,删除的数据为:" << e << endl;
	else
		cout << "位置不对,删除失败!" << endl;
}
 
//3、取值
void GetElem(LinkList L)
{
	ElemType e;
	int i;
	bool flag;
	cout << "请输入要获取数据的位置:" << endl;
	cin >> i;
	flag = GetElem(L, i, e);
	if (flag)
		cout << "获取的数据为:" << e << endl;
	else
		cout << "位置不对,获取数据失败!" << endl;
}
 
//4、查找
void LocateElem(LinkList L)
{
	ElemType e;
	LNode* p = NULL;
	bool flag;
	cout << "请输入要查找的数据:" << endl;
	cin >> e;
	flag = LocateElem(L, p, e);
	if (flag)
		cout << "查找成功,该数据的地址为:" << p << endl;
	else
		cout << "查找失败!" << endl;
}
 
//5、判空
void ListEmpty(LinkList L)
{
	if (L->next)
		cout << "链表不为空!" << endl;
	else
		cout << "链表为空!" << endl;
}
 
//6、求长
void ListLength(LinkList L)
{
	LinkList p = L->next;//p指向第一个结点
	int i = 0;
	while (p)//遍历单链表,统计结点数
	{
		i++;
		p = p->next;
	}
	cout << "链表的长度为:" << i << endl;
}
 
//7、清空
void ClearList(LinkList& L)
{
	LNode* p, * q;
	p = L->next;
	while (p)//从首元结点开始,依次删除
	{
		q = p->next;
		delete p;
		p = q;
	}
	L->next = NULL;//头结点指针域置空
}
 
//8、销毁
void DestroyList(LinkList& L)
{
	LNode* p;
	while (L)//从头结点开始依次删除
	{
		p = L;
		L = L->next;
		delete p;
	}
}
 
//9、打印
void PrintList(LinkList L)
{
	LinkList p = L->next;//p指向第一个结点
	int i = 0;
	while (p)//遍历单链表
	{
		i++;
		cout << "链表第" << i << "个数据为:" << p->data << endl;
		p = p->next;
	}
}
 
//菜单
void menu()
{
	cout << "***************************************************************************" << endl;
	cout << "***********************************1、插入*********************************" << endl;
	cout << "***********************************2、删除*********************************" << endl;
	cout << "***********************************3、取值*********************************" << endl;
	cout << "***********************************4、查找*********************************" << endl;
	cout << "***********************************5、判空*********************************" << endl;
	cout << "***********************************6、求长*********************************" << endl;
	cout << "***********************************7、清空*********************************" << endl;
	cout << "***********************************8、销毁*********************************" << endl;
	cout << "***********************************9、打印*********************************" << endl;
	cout << "***********************************0、退出*********************************" << endl;
	cout << "***************************************************************************" << endl;
}
 
int main()
{
	LinkList L;
	InitList(L);
	int select;
	cout << "请先创建单链表:1、前插法!  2、后插法!" << endl;
	cin >> select;
	switch (select)
	{
	case 1://插入
		CreateList_H(L);
		system("pause");//按任意键继续
		break;
	case 2://删除
		CreateList_R(L);
		system("pause");
		break;
	default:
		cout << "输入有误,创建失败!" << endl;
		system("pause");
		break;
	}
	while (1)
	{
		system("CLS");//清屏操作
		menu();
		cout << "请输入菜单序号:" << endl;
		cin >> select;
		switch (select)
		{
		case 1://插入
			ListInsert(L);
			system("pause");//按任意键继续
			break;
		case 2://删除
			ListDelete(L);
			system("pause");
			break;
		case 3://取值
			GetElem(L);
			system("pause");
			break;
		case 4://查找
			LocateElem(L);
			system("pause");
			break;
		case 5://判断链表是否为空
			ListEmpty(L);
			system("pause");
			break;
		case 6://求单链表的长度
			ListLength(L);
			system("pause");
			break;
		case 7://清空
			ClearList(L);
			system("pause");
			break;
		case 8://销毁
			DestroyList(L);
			system("pause");
			return 0;
			break;
		case 9://打印
			PrintList(L);
			system("pause");
			break;
		case 0:
			cout << "欢迎下次使用!" << endl;//退出
			system("pause");
			return 0;
			break;
		default:
			cout << "菜单序号输入有误!" << endl;
			system("pause");
			break;
		}
	}
	system("pause");
	return 0;
}
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 中文实名注册

本版积分规则

小黑屋|东台市机器人学会 ( 苏ICP备2021035350号-1;苏ICP备2021035350号-2;苏ICP备2021035350号-3 )

GMT+8, 2024-11-23 16:13 , Processed in 0.041118 second(s), 29 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表