【数据结构周周练】001顺序表与链表(含上海大学832计算机组成原理与数据结构原题)

本文主要是介绍【数据结构周周练】001顺序表与链表(含上海大学832计算机组成原理与数据结构原题),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

前言

一、练习1:删除顺序表指定部分元素

1、题目

2、代码

3、运行结果

二、练习2:逆置链表

1、题目

2、代码

3、运行结果

三、练习3:拆分链表

1、题目

2、代码

3、运行结果


前言

从这周开始,我会不定期发一些数据结构练习题,一方面,提升自己的编程能力,给自己考研代码题打基础,虽然逻辑都明白,但是一次性写对代码还是有问题,思维不细致;另一方面,给想学习数据结构的同学提供一些编程的练习题,希望能对大家有所帮助。题目代码方式不唯一,欢迎大家提供新的解题思路或代码

一、练习1:删除顺序表指定部分元素

1、题目

从给定顺序表中删除i~j的所有元素(包括i,j)。以顺序表:0123456789为例,i取3,j取6。

2、代码

#define MAXLISTSIZE 20
#define LISTINCREMENT 5
#define OVERFLOW -1#include<iostream>
#include<malloc.h>using namespace std;typedef int ElemType;
typedef struct{ElemType *elem;int length;int listSize;
}SqList;int InitSqList(SqList &S) {S.elem = (ElemType *)malloc(MAXLISTSIZE * sizeof(SqList));if (!S.elem){return OVERFLOW;}S.length = 0;S.listSize = MAXLISTSIZE;
}int CreatSqList(SqList &S) {for (int i = 0; i <= 9; i++){if (S.length>S.listSize){ElemType * newBase = (ElemType *)realloc(S.elem, (S.listSize + LISTINCREMENT) * sizeof(ElemType));//重新分配基地址S.elem = newBase;if (!S.elem){return OVERFLOW;}}S.length++;S.elem[i] = i;}return 1;
}int DeleteElem(SqList &S) {for (int i = 7; i <= S.length; i++){S.elem[i-4] = S.elem[i];}S.length -= 4;return 1;
}void VisitSqList(SqList S) {for (int i = 0; i < S.length; i++){cout << S.elem[i] << ",";}cout << endl;
}
void main() {SqList S;InitSqList(S);CreatSqList(S);cout << "原顺序表为:" << endl;VisitSqList(S);DeleteElem(S);cout << "删除元素后顺序表为:" << endl;VisitSqList(S);
}

3、运行结果

二、练习2:逆置链表

1、题目

创建一个长度为10的线性单链表:0123456789。并将其逆置,要求逆置过程不能创立新结点。

2、代码

#include<iostream>
#include<malloc.h>
using namespace std;typedef int ElemType;//建立链表
typedef struct LNode
{ElemType elem;struct LNode *next;
}LNode,*LinkList;//初始化链表
int InitList(LinkList &L) {L = (LinkList)malloc(sizeof(LNode));if (!L)//存储分配失败exit(OVERFLOW);L->next = NULL;return 1;
}//尾插法创建链表
int CreatList(LinkList &L) {L->elem = 0;LinkList p = L;LinkList q;for (int i = 1; i <= 9; i++){q = (LinkList)malloc(sizeof(LNode));q->elem = i;q->next = NULL;p->next = q;p = q;q = p->next;}return 1;
}//头插法逆置链表
int HeadInsertList(LinkList &L) {LinkList p,q;p = L->next;q = p;L->next = NULL;while (q){q = p->next;p->next = L;L = p;p = q;}return 1;
}//遍历链表,查看逆置结果。
void VisitList(LinkList L) {LinkList p = L;while (p){cout << p->elem << ",";p = p->next;}cout << endl;
}
void main() {LinkList L;InitList(L);CreatList(L);cout << "遍历L:" << endl;VisitList(L);HeadInsertList(L);cout << "遍历逆序后的L" << endl;VisitList(L);
}

3、运行结果

三、练习3:拆分链表

1、题目

将一个长度为10的线性单链表:0123456789中的偶数取出,放到另一个单链表中,要求保持原来顺序。

2、代码

#include<iostream>
#include<malloc.h>
using namespace std;typedef int ElemType;//建立链表
typedef struct LNode
{ElemType elem;struct LNode *next;
}LNode, *LinkList;//初始化链表
int InitList(LinkList &L) {L = (LinkList)malloc(sizeof(LNode));if (!L)//存储分配失败exit(OVERFLOW);L->next = NULL;return 1;
}//尾插法创建链表
int CreatList(LinkList &L) {LinkList p = L;LinkList q;for (int i = 0; i <= 9; i++){q = (LinkList)malloc(sizeof(LNode));q->elem = i;q->next = NULL;p->next = q;p = q;q = p->next;}return 1;
}
//分解链表
int ApartList(LinkList &L, LinkList &M) {LinkList p = L;LinkList q = L->next;LinkList m = M;while (q){if (q->elem % 2 == 0){p->next = q->next;p = q->next;m->next = q;			q->next = NULL;m = q;}q = p->next;}return 1;
}void VisitList(LinkList &L) {LinkList p = L->next;while (p){cout << p->elem << ",";p = p->next;}cout << endl;
}void main() {LinkList L, M;InitList(L);CreatList(L);cout << "分解前的L链表为:";VisitList(L);InitList(M);ApartList(L, M);cout << "分解后的L链表为:";VisitList(L);cout << "分解后的M链表为:";VisitList(M);
}

3、运行结果

这篇关于【数据结构周周练】001顺序表与链表(含上海大学832计算机组成原理与数据结构原题)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/482125

相关文章

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

Java中JSON格式反序列化为Map且保证存取顺序一致的问题

《Java中JSON格式反序列化为Map且保证存取顺序一致的问题》:本文主要介绍Java中JSON格式反序列化为Map且保证存取顺序一致的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未... 目录背景问题解决方法总结背景做项目涉及两个微服务之间传数据时,需要提供方将Map类型的数据序列化为co

Mysql的主从同步/复制的原理分析

《Mysql的主从同步/复制的原理分析》:本文主要介绍Mysql的主从同步/复制的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录为什么要主从同步?mysql主从同步架构有哪些?Mysql主从复制的原理/整体流程级联复制架构为什么好?Mysql主从复制注意

Nacos注册中心和配置中心的底层原理全面解读

《Nacos注册中心和配置中心的底层原理全面解读》:本文主要介绍Nacos注册中心和配置中心的底层原理的全面解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录临时实例和永久实例为什么 Nacos 要将服务实例分为临时实例和永久实例?1.x 版本和2.x版本的区别

apache的commons-pool2原理与使用实践记录

《apache的commons-pool2原理与使用实践记录》ApacheCommonsPool2是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能,这篇文章主... 目录一、核心原理与组件二、使用步骤详解(以数据库连接池为例)三、高级配置与优化四、典型应用场景五、注意事

电脑系统Hosts文件原理和应用分享

《电脑系统Hosts文件原理和应用分享》Hosts是一个没有扩展名的系统文件,当用户在浏览器中输入一个需要登录的网址时,系统会首先自动从Hosts文件中寻找对应的IP地址,一旦找到,系统会立即打开对应... Hosts是一个没有扩展名的系统文件,可以用记事本等工具打开,其作用就是将一些常用的网址域名与其对应

无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案

《无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案》:本文主要介绍了无法启动此程序,详细内容请阅读本文,希望能对你有所帮助... 在计算机使用过程中,我们经常会遇到一些错误提示,其中之一就是"api-ms-win-core-path-l1-1-0.dll丢失

Dubbo之SPI机制的实现原理和优势分析

《Dubbo之SPI机制的实现原理和优势分析》:本文主要介绍Dubbo之SPI机制的实现原理和优势,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Dubbo中SPI机制的实现原理和优势JDK 中的 SPI 机制解析Dubbo 中的 SPI 机制解析总结Dubbo中

MySQL中SQL的执行顺序详解

《MySQL中SQL的执行顺序详解》:本文主要介绍MySQL中SQL的执行顺序,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql中SQL的执行顺序SQL执行顺序MySQL的执行顺序SELECT语句定义SELECT语句执行顺序总结MySQL中SQL的执行顺序