一、判断题:

二、选择题:

三、编程题:

  7-1 jmu-ds-顺序表区间元素删除 :

输入样例:

10
5 1 9 10 67 12 8 33 6 2
3 10

输出样例:

1 67 12 33 2

代码:

#include<stdio.h>
int main()
{
int a[10001];
int b[10001];//开辟两个比较大的数组
int n;
scanf("%d",&n);
int i;
for(i=0;i<n;i++)
scanf("%d",&a[i]);//将数读入
int x, y;
int j=0;
scanf("%d %d",&x,&y);
for(i=0;i<n;i++)//利用区间判断大小,将区间以外的数加入新数组
{
if(a[i]<x||a[i]>y)
{
b[j]=a[i];
j++;
}
}
printf("%d",b[0]);
for(i=1;i<j;i++)
{
printf(" %d",b[i]);
}
}

  

  7-2 两个有序链表序列的合并:

输入样例:

1 3 5 -1
2 4 6 8 10 -1

输出样例:

1 2 3 4 5 6 8 10

代码:

#include<stdio.h>
#include<stdlib.h>
typedef struct LNode//链表
{
int data;
struct LNode *next;
}LNode, *LinkList;
void MergeList_L(LinkList La, LinkList Lb, LinkList Lc)//排序
{
La=La->next;
Lb=Lb->next;
while(La!=NULL&&Lb!=NULL)
{
if(La->data > Lb->data)
{
Lc->next=Lb;
Lb=Lb->next;
}
else
{
Lc->next=La;
La=La->next;
}
Lc=Lc->next;
}
if(La==NULL&&Lb==NULL) return;
if(La!=NULL)
Lc->next=La;
else
Lc->next=Lb;
return;
}
LinkList InitList()//
{
LinkList l;
l=(LinkList) malloc (sizeof(struct LNode));
if(!l) return NULL;
l->next=NULL;
return l;
}
void ReadList_L(LinkList LLL)//读取
{
LinkList temp;
int data;
scanf("%d",&data);
while(data>0)
{
temp=(LinkList)malloc(sizeof(struct LNode));
if(!temp)return;
temp->data=data;
temp->next=NULL;
LLL->next=temp;
LLL=temp;
scanf("%d",&data);
}
return;
}
void PrintList_L(LinkList LL)//打印
{
LL=LL->next;
if(LL==NULL)
{
printf("NULL");
return;
}
while(LL)
{
if(LL->next==NULL)
printf("%d",LL->data);
else printf("%d ",LL->data);
LL=LL->next;
}
}
int main()
{
LinkList s1,s2,S;
s1 = InitList();
s2 = InitList();
S = InitList();
ReadList_L(s1);
ReadList_L(s2);
MergeList_L(s1, s2, S);
PrintList_L(S);
return 0;
}

  7-3 两个有序链表序列的交集:

输入样例:

1 2 5 -1
2 4 5 8 10 -1

输出样例:

2 5

代码:

#include<stdio.h>
int a[10000001],b[100000001];
int L1=0,L2=0;
#define true 1
int main()
{
int i=0,j=0,index=-1;
while(true)//依次读入数组
{
int aa;
scanf("%d",&aa);
if(aa==-1)
break;
else
a[L1]=aa,L1++;
}
while(true)//依次读入数组
{
int bb;
scanf("%d",&bb);
if(bb==-1)
break;
else
b[L2]=bb,L2++;
}
while(i<L1 && j<L2)
{
if(a[i]==b[j])//出现交集,按规定格式输出
{
if(index==-1)
{
printf("%d",a[i]);
}
else
{
printf(" %d",a[i]);
}
i++,j++,index++;
}
else if(a[i] > b[j])//第一个数组对应的数值大于第二个,让第二个数组的下一个进行比较
j++;
else
i++;
}
if(index==-1)
printf("NULL\n");
else
printf("\n");
return 0;
}

  

  7-4 一元多项式的乘法与加法运算:

输入样例:

4 3 4 -5 2  6 1  -2 0
3 5 20 -7 4 3 1

输出样例:

15 24 -25 22 30 21 -10 20 -21 8 35 6 -33 5 14 4 -15 3 18 2 -6 1
5 20 -4 4 -5 2 9 1 -2 0

代码:

#include<iostream>
#include<cstring>
using namespace std;
int t1[1005],t2[1005],s1[2005],s2[2005];//定义全局数组
int main(){
int n1,n2,a,b;
memset(t1,0,sizeof(t1));
memset(t2,0,sizeof(t2));
memset(s1,0,sizeof(s1));
memset(s2,0,sizeof(s2));//初始化数组
cin>>n1;//先输入系数,后输入指数
for(int i=0;i<n1;i++){
cin>>a>>b;
t1[b]=a;
}
cin>>n2;
for(int i=0;i<n2;i++){
cin>>a>>b;
t2[b]=a;
}////指数作为下标,系数作为数组元素
for(int i=0;i<=1000;i++){
for(int j=0;j<=1000;j++){
s1[i+j]+=t1[i]*t2[j];
}
}
for(int o=0;o<=1000;o++){
s2[o]+=t1[o]+t2[o];
}
int tag=0;
for(int i=2000;i>=0;i--)
if(s1[i]!=0){
if(tag)
cout<<" ";
tag=1;
cout<<s1[i]<<" "<<i;
}//判断个事进行输出
if(!tag)cout<<"0 0";
cout<<endl;
tag=0;
for(int i=1000;i>=0;i--)
if(s2[i]!=0){
if(tag)
cout<<" ";
tag=1;
cout<<s2[i]<<" "<<i;
}//同上
if(!tag)cout<<"0 0";
cout<<endl;
return 0;
}

  

  7-5 一元多项式求导:

输入样例:

3 4 -5 2 6 1 -2 0

输出样例:

12 3 -10 1 6 0

代码:

#include<bits/stdc++.h>
using namespace std;
int main()
{
int a, b;
int s = 0;//用于计算系数和幂的乘积
cin>>a>>b;
if(b != 0)
cout<<(a*b)<<" "<<(b-1);//先计算一组,方便最后一组末尾的消除空格
else//特殊情况:即多项式为常数的情况
{
cout<<"0 0";
return 0;
}
while(scanf("%d %d", &a, &b) != EOF)//输入多组数据
{
if(b != 0)
{
s = a*b;
cout<<" "<<s<<" "<<(b-1);//进行求导计算
}
}
return 0;
}

  

  7-6 求链式线性表的倒数第K项 :

输入样例:

4 1 2 3 4 5 6 7 8 9 0 -1

输出样例:

7        

代码:

#include<stdio.h>
int a[1000001];//第一次提交显示数组越界(段错误)
int main()
{ int look_for;
scanf("%d",&look_for);//读入下标
int index;
int i = 0;
while(scanf("%d",&index)>=0)//将大于等于0的数读入
{
a[i]=index;
i++;
}
i--;//循环里面多一次i++,减掉
if(i-look_for<0)//判断下标是否符合要求
{
printf("NULL\n");
}
else
{
printf("%d\n",a[i-look_for]);
}
return 0;
}

SDUST数据结构 - chap2 线性表的更多相关文章

  1. 用C#学习数据结构之线性表

    什么是线性表 线性表是最简单.最基本.最常用的数据结构.线性表是线性结构的抽象(Abstract),线性结构的特点是结构中的数据元素之间存在一对一的线性关系.这种一对一的关系指的是数据元素之间的位置关 ...

  2. 数据结构之线性表(python版)

    数据结构之线性表(python版) 单链表 1.1  定义表节点 # 定义表节点 class LNode(): def __init__(self,elem,next = None): self.el ...

  3. C语言数据结构-顺序线性表的实现-初始化、销毁、长度、查找、前驱、后继、插入、删除、显示操作

    1.数据结构-顺序线性表的实现-C语言 #define MAXSIZE 100 //结构体定义 typedef struct { int *elem; //基地址 int length; //结构体当 ...

  4. javascript实现数据结构:线性表--简单示例及线性表的顺序表示和实现

    线性表(linear list)是最常用且最简单的一种数据结构.一个线性表是n个数据元素的有限序列.在稍复杂的线性表中,一个数据元素可以由若干个数据项(item)组成. 其中: 数据元素的个数n定义为 ...

  5. javascript实现数据结构:线性表--线性链表(链式存储结构)

    上一节中, 线性表的顺序存储结构的特点是逻辑关系上相邻的两个元素在物理位置上也相邻,因此可以随机存取表中任一元素,它的存储位置可用一个简单,直观的公式来表示.然后,另一方面来看,这个特点也造成这种存储 ...

  6. Java数据结构之线性表(2)

    从这里开始将要进行Java数据结构的相关讲解,Are you ready?Let's go~~ java中的数据结构模型可以分为一下几部分: 1.线性结构 2.树形结构 3.图形或者网状结构 接下来的 ...

  7. Java数据结构之线性表

    从这里开始将要进行Java数据结构的相关讲解,Are you ready?Let's go~~ java中的数据结构模型可以分为一下几部分: 1.线性结构 2.树形结构 3.图形或者网状结构 接下来的 ...

  8. C 数据结构1——线性表分析(顺序存储、链式存储)

    之前是由于学校工作室招新,跟着大伙工作室招新训练营学习数据结构,那个时候,纯碎是小白(至少比现在白很多)那个时候,学习数据结构,真的是一脸茫然,虽然写出来了,但真的不知道在干嘛.调试过程中,各种bug ...

  9. 算法与数据结构(一) 线性表的顺序存储与链式存储(Swift版)

    温故而知新,在接下来的几篇博客中,将会系统的对数据结构的相关内容进行回顾并总结.数据结构乃编程的基础呢,还是要不时拿出来翻一翻回顾一下.当然数据结构相关博客中我们以Swift语言来实现.因为Swift ...

随机推荐

  1. 20201204-3 opp编程好处

    面向对象编程(Object-Oriented Programming )介绍 对于编程语言的初学者来讲, OOP不是一个很容易理解的编程方式,大家虽然都按老师讲的都知道0OP的三大特性是 继承.封装. ...

  2. Taro 周报 #7: 收获「e代驾」案例,发布 v2.2.16 和 v3.2.0-canary.2

    Taro 周报 2020 年 12 月 05 日 - 2020 年 12 月 12 日 ,更多的Taro周报点击 Taro 大事件 58 技术发布文章<开源 | Taro 3 支持 React ...

  3. Netty源码解析 -- PoolSubpage实现原理

    前面文章说了PoolChunk如何管理Normal内存块,本文分享PoolSubpage如何管理Small内存块. 源码分析基于Netty 4.1.52 内存管理算法 PoolSubpage负责管理S ...

  4. SpringBoot事件监听机制及观察者模式/发布订阅模式

    目录 本篇要点 什么是观察者模式? 发布订阅模式是什么? Spring事件监听机制概述 SpringBoot事件监听 定义注册事件 注解方式 @EventListener定义监听器 实现Applica ...

  5. k8s应用环境

    1.7:k8s应用环境: 1.7.1:dashboard(1.10.1) 部署kubernetes的web管理界面dashboard 参考文档: https://www.jianshu.com/p/4 ...

  6. MGRE实验--内网为OSPF

    实验要求: R2为ISP,只能配置IP地址 R1.R3.R4之间构建MGRE环境,仅R1IP地址固定 内网使用OSPF获取路由,全网可达 拓扑: 1.配置IP地址 2.配置缺省 3.配置MGRE环境 ...

  7. ASP.NET Core 3.1使用 AutoMapper

    多层架构中存在多种模型,如视图模型ViewModel,数据传输对你DTO,ORM对象等,这些数据在层与层之间进行传输必须涉及类型之间的转换. AutoMapper是一个对象-对象映射器,作用是通过设置 ...

  8. Core3.0使用Swagger接口文档

    前言 此方法为百度搜索结果,原文链接找不到了 步骤 1.引用Nuget Swashbuckle.AspNetCore 2.Startup.cs配置 //注册swagger服务,定义1个或者多个swag ...

  9. EF快速入门--直接修改(简要介绍ObjectContext处理机制)

    原博文 http://www.cnblogs.com/fly_dragon/archive/2011/06/05/2073084.html ObjectContext的处理机制 ObjectConte ...

  10. Java Int类型与字符,汉字之间的转换

    /** * java 中的流主要是分为字节流和字符流 * 再一个角度分析的话可以分为输入流和输出流 * 输入和输出是一个相对的概念 相对的分别是jvm虚拟机的内存大小 * 从另一个角度讲Java或者用 ...