【数据结构周周练】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

相关文章

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制

Redis主从复制的原理分析

《Redis主从复制的原理分析》Redis主从复制通过将数据镜像到多个从节点,实现高可用性和扩展性,主从复制包括初次全量同步和增量同步两个阶段,为优化复制性能,可以采用AOF持久化、调整复制超时时间、... 目录Redis主从复制的原理主从复制概述配置主从复制数据同步过程复制一致性与延迟故障转移机制监控与维

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R

Redis主从复制实现原理分析

《Redis主从复制实现原理分析》Redis主从复制通过Sync和CommandPropagate阶段实现数据同步,2.8版本后引入Psync指令,根据复制偏移量进行全量或部分同步,优化了数据传输效率... 目录Redis主DodMIK从复制实现原理实现原理Psync: 2.8版本后总结Redis主从复制实

JAVA利用顺序表实现“杨辉三角”的思路及代码示例

《JAVA利用顺序表实现“杨辉三角”的思路及代码示例》杨辉三角形是中国古代数学的杰出研究成果之一,是我国北宋数学家贾宪于1050年首先发现并使用的,:本文主要介绍JAVA利用顺序表实现杨辉三角的思... 目录一:“杨辉三角”题目链接二:题解代码:三:题解思路:总结一:“杨辉三角”题目链接题目链接:点击这里

如何测试计算机的内存是否存在问题? 判断电脑内存故障的多种方法

《如何测试计算机的内存是否存在问题?判断电脑内存故障的多种方法》内存是电脑中非常重要的组件之一,如果内存出现故障,可能会导致电脑出现各种问题,如蓝屏、死机、程序崩溃等,如何判断内存是否出现故障呢?下... 如果你的电脑是崩溃、冻结还是不稳定,那么它的内存可能有问题。要进行检查,你可以使用Windows 11

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

csu1329(双向链表)

题意:给n个盒子,编号为1到n,四个操作:1、将x盒子移到y的左边;2、将x盒子移到y的右边;3、交换x和y盒子的位置;4、将所有的盒子反过来放。 思路分析:用双向链表解决。每个操作的时间复杂度为O(1),用数组来模拟链表,下面的代码是参考刘老师的标程写的。 代码如下: #include<iostream>#include<algorithm>#include<stdio.h>#

hdu4407(容斥原理)

题意:给一串数字1,2,......n,两个操作:1、修改第k个数字,2、查询区间[l,r]中与n互质的数之和。 解题思路:咱一看,像线段树,但是如果用线段树做,那么每个区间一定要记录所有的素因子,这样会超内存。然后我就做不来了。后来看了题解,原来是用容斥原理来做的。还记得这道题目吗?求区间[1,r]中与p互质的数的个数,如果不会的话就先去做那题吧。现在这题是求区间[l,r]中与n互质的数的和