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

相关文章

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

文章目录 前言一、协同过滤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互质的数的和

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

深入手撕链表

链表 分类概念单链表增尾插头插插入 删尾删头删删除 查完整实现带头不带头 双向链表初始化增尾插头插插入 删查完整代码 数组 分类 #mermaid-svg-qKD178fTiiaYeKjl {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-

顺序表之创建,判满,插入,输出

文章目录 🍊自我介绍🍊创建一个空的顺序表,为结构体在堆区分配空间🍊插入数据🍊输出数据🍊判断顺序表是否满了,满了返回值1,否则返回0🍊main函数 你的点赞评论就是对博主最大的鼓励 当然喜欢的小伙伴可以:点赞+关注+评论+收藏(一键四连)哦~ 🍊自我介绍   Hello,大家好,我是小珑也要变强(也是小珑),我是易编程·终身成长社群的一名“创始团队·嘉宾”

hdu4407容斥原理

题意: 有一个元素为 1~n 的数列{An},有2种操作(1000次): 1、求某段区间 [a,b] 中与 p 互质的数的和。 2、将数列中某个位置元素的值改变。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.Inpu

hdu4059容斥原理

求1-n中与n互质的数的4次方之和 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;import java.io.PrintWrit