单选题

2-1   数组A[1..5,1..6]每个元素占5个单元,将其按行优先次序存储在起始地址为1000的连续的内存单元中,则元素A[5,5]的地址为:

 A.1120      B.1125     C.1140     D.1145

解析   答案为C,

1000

A[1,1]...A[1,6] +6*5

A[2,1]...A[2,6] +6*5

A[3,1]...A[3,6] +6*5

A[4,1]...A[4,6] +6*5

A[5,1]...A[5,5] +5*5

1000 + (6*5)*4 + 5*5 = 1000 + 120 + 25 = 1145

但是1145是A[5,5]之后的内存单元的地址(也就是A[5,6]的首地址)。因此A[5,5]的首地址是1145-5=1140。

2-5   有一个100阶的三对角矩阵\(M\),其三对角元素\(m_{i,j}\)(1≤\(i\)≤100,1≤\(j\)≤100)按行优先次序压缩存入下标从0开始的一维数组\(N\)中。元素\(m_{30,30}\)在\(N\)中的下标是:

 A.86      B.87      C.88      D.89

解析    答案为B,解答此题的关键在于什么是三对角矩阵(来源:三对角矩阵压缩),如下图所示:



除了第一行和最后一行是每行2个元素外,中间的每行都是三个元素。

因此,答案显而易见,\(m_{30,30}\)编号就是2+3*28+2 -1= 87;

2-6   设有一个 12×12 的对称矩阵\(M\),将其上三角部分的元素\(m_{i,j}\)(1≤\(i\)≤\(j\)≤12)按行优先存入C语言的一维数组\(N\)中,元素\(m_{6,6}\)在\(N\)中的下标是:

 A.50      B.51      C.55      D.66

解析    答案为A,上三角矩阵从第一行开始元素数量依次是:12,11,10,9,8,7,6,5,4,3,2,1,m6,6表示上三角区域的第6行第1个,所以m6,6为第51个元素,占数组位置为a[50]。

函数题 数组元素的区间删除

给定一个顺序存储的线性表,请设计一个函数删除所有值大于min而且小于max的元素。删除后表中剩余元素保持顺序存储,并且相对位置不能改变。

函数接口定义:

int Delete( int A[], int L, int minA, int maxA );

其中A是整型数组,存储原始线性表的元素;L是表长,即A中元素的个数;minAmaxA分别为待删除元素的值域的下、上界。函数Delete应将A中所有值大于minA而且小于maxA的元素删除,同时保证表中剩余元素保持顺序存储,并且相对位置不变,最后返回删除后的表长。

裁判测试程序样例:

#include <stdio.h>
#define MAXN 20
int Delete( int A[], int L, int minA, int maxA );
int main()
{
int A[MAXN], L, minA, maxA, i;
scanf("%d", &L);
for (i=0; i<L; i++) scanf("%d", &A[i]);
scanf("%d %d", &minA, &maxA);
L = Delete(A, L, minA, maxA);
for (i=0; i<L; i++) printf("%d ", A[i]);
printf("\n"); return 0;
}
/* 你的代码将被嵌在这里 */

输入样例:

10
4 -8 2 12 1 5 9 3 3 10
0 4

输出样例:

4 -8 12 5 9 10

Time Limit Exceeded

一开始的时候,觉得这题很简单,直接的思路就是,从0到L-1遍历,每当找到符合题目要求的A[i]是进行删除操作,即运用一个for循环,让i+1到L-1的数组元素提前(特别注意一下,提前完之后,在把L减1的同时,i也需要减去1,因为此时的A[i]是原来的A[i+1]。具体代码如下:

int Delete( int A[], int L, int minA, int maxA ){
for(int i=0;i<L;i++){
if(A[i]>minA&&A[i]<maxA) {
for(int j=i;j<L-1;j++)
A[j]=A[j+1];
L--;
i--; //此时A[i]的值发生改变,需重新判断
}
}
return L;
}

显而易见,其时间复杂度为\(O(n^{2})\),不够效率,并且提交上去也有一个点超时。因此只能改变解题思路了。

Accepted

第二种做法,我们通过第一种做法进行改进。我们发现,在第一种做法中,我们每遇到一个符合题意的数组元素就要从它到数组末尾进行一次遍历删除,这样使程序一直在做重复的事,那么有没有办法可以减少一遍遍重复做删去的事呢?我想到的是,我将不需要被删去的数组元素存到一个新的数组里,定义一个变量k来记录这个数组里元素的个数,并在最后将这个数组里的元素赋值给原数组,同时返回k值,这样做法我们会发现时间复杂度变为了\(O(n)\),使程序变得高效了许多。代码如下:

int Delete( int A[], int L, int minA, int maxA ){
int B[MAXN],k=0;
for(int i=0;i<L;i++)
if(A[i]<=minA||A[i]>=maxA)
B[k++]=A[i];
for(int i=0;i<k;i++)
A[i]=B[i];
return k;
}

编程题  数组元素的区间删除

给定一个顺序存储的线性表,请设计一个算法查找该线性表中最长的连续递增子序列。例如,(1,9,2,5,7,3,4,6,8,0)中最长的递增子序列为(3,4,6,8)。

输入格式:

输入第1行给出正整数n(≤105);第2行给出n个整数,其间以空格分隔。

输出格式:

在一行中输出第一次出现的最长连续递增子序列,数字之间用空格分隔,序列结尾不能有多余空格。

输入样例:

15
1 9 2 5 7 3 4 6 8 0 11 15 17 17 10

输出样例:

3 4 6 8

Accepted

这一题,我就采用了\(O(n)\)的算法,通过一次遍历,找出第一次出现的最长连续递增子序列,当然,可能还会有些地方写的不够简便,也同时希望大家可以提供更多好的意见来相互交流学习。

#include <iostream>
using namespace std;
int main() {
int n,a[100000];
int max=0;
int num=1;
int left=0,right=0;
int L=0,R=0;
cin >> n;
for(int i=0;i<n;i++)
cin >> a[i];
for(int i=1;i<n;i++){
if(a[i]>a[i-1]){
right=i;
num++;
}
else{
if(num>max){
L=left;
R=right;
max=num;
}
right=i;
left=i;
num=1;
}
}
if(num>max){
L=left;
R=right;
}
for(int i=L;i<=R;i++){
cout << a[i] ;
if(i!=R) cout <<" ";
else cout << endl;
} return 0;
}

FZU_DS_2019_SequenceList的更多相关文章

随机推荐

  1. CF643F-Bears and Juice【组合数学】

    正题 题目链接:https://www.luogu.com.cn/problem/CF643F 题目大意 题目有点奇怪就直接放翻译了 有 \(n\) 只熊和若干桶果汁和恰好一桶酒,每一天每只熊会选择一 ...

  2. Fortran学习笔记:03 数组(Array)

    Fortran学习笔记目录 书接上回:Fortran学习笔记:02 流控制语句 数组(Array) 定义数组 一维数组 program main implicit none integer :: i ...

  3. Linux从头学15:【页目录和页表】-理论 + 实例 + 图文的最完全、最接地气详解

    作 者:道哥,10+年嵌入式开发老兵,专注于:C/C++.嵌入式.Linux. 关注下方公众号,回复[书籍],获取 Linux.嵌入式领域经典书籍:回复[PDF],获取所有原创文章( PDF 格式). ...

  4. 《手把手教你》系列技巧篇(二十五)-java+ selenium自动化测试-FluentWait(详细教程)

    1.简介 其实今天介绍也讲解的也是一种等待的方法,有些童鞋或者小伙伴们会问宏哥,这也是一种等待方法,为什么不在上一篇文章中竹筒倒豆子一股脑的全部说完,反而又在这里单独写了一篇.那是因为这个比较重要,所 ...

  5. L1-027 出租 (20 分) java题解

    下面是新浪微博上曾经很火的一张图: 一时间网上一片求救声,急问这个怎么破.其实这段代码很简单,index数组就是arr数组的下标,index[0]=2 对应 arr[2]=1,index[1]=0 对 ...

  6. 云原生的弹性 AI 训练系列之三:借助弹性伸缩的 Jupyter Notebook,大幅提高 GPU 利用率

    Jupyter Notebooks 在 Kubernetes 上部署往往需要绑定一张 GPU,而大多数时候 GPU 并没有被使用,因此利用率低下.为了解决这一问题,我们开源了 elastic-jupy ...

  7. PTA习题6-8 统计一行文本的单词个数 (15分)

    参考<c和指针>里面运用strtok函数打印空白标记符(如\n,\t)的程序改写而成的代码 在之前我自己写了一个60行的链表版本的统计程序 相比之下这个strtok函数的程序要简洁明了的多 ...

  8. 自定义ConditionalOnXX注解

    一.Conditional注解介绍 对SpringBoot有足够了解的小伙伴应该都用过Conditional系列注解,该注解可用在类或者方法上用于控制Bean的初始化. 常用的Conditional注 ...

  9. Golang通脉之结构体

    Go语言中的基础数据类型可以表示一些事物的基本属性,但是要表达一个事物的全部或部分属性时,这时候再用单一的基本数据类型明显就无法满足需求了,Go语言提供了一种自定义数据类型,可以封装多个基本数据类型, ...

  10. Golang通脉之流程控制

    流程控制是每种编程语言控制逻辑走向和执行次序的重要部分,流程控制可以说是一门语言的"经脉". Go语言中最常用的流程控制有if和for,而switch和goto主要是为了简化代码. ...