单选题

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. YbtOJ#652-集合比较【Treap】

    正题 题目链接:http://www.ybtoj.com.cn/problem/652 题目大意 定义一个元素为一个有序集合包含两个元素\(C=\{A,B\}\) 集合\(C=\{A,B\}\)的大小 ...

  2. mqtt网关服务器连接阿里云关联物模型

    mqtt网关服务器连接阿里云关联物模型 卓岚专门为工业环境设计的RS485设备数据采集器/物联网网关,兼具串口服务器.Modbus网关.MQTT网关.RS485转JSON等多种功能于一体. 可以连接阿 ...

  3. Flask SSTI利用方式的探索

    Flask SSTI利用方式的探索 一.SSTI简介&环境搭建 ​ 一个统一风格的站点,其大多数页面样式都是一致的,只是每个页面显示的内容各不相同.要是所有的逻辑都放在前端进行,无疑会影响响应 ...

  4. 【Golang】三个点(...)用法

    众所周知,Go语言是严格类型语言,而开发的时候又遇到传入参数不定的情况,怎么办? 这里的三个点(-),就给我们编程人员带来很大的灵活性,具体如下 在Golang中,三个点一共会用在四个地方(话说三个点 ...

  5. mysql创建库

    建库 GBK: create database test2 DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci; UTF8: CREATE DATABAS ...

  6. js 判断一个变量是否有值

    最近遇到一个面试题,判断一个变量是否有值,当时有点蒙,其实很简单,就是判断 变量是否为 undefined或者null function isFlag(val) { if(Object.prototy ...

  7. 题解 Weak in the Middle

    题目传送门 Description 有一个长度为 \(n\) 的序列 \(a_{1,2,...,n}\) ,每次可以删掉 \(a_i\),当 \(\min(a_{i-1},a_{i+1})>a_ ...

  8. 洛谷3973 TJOI2015线性代数(最小割+思维)

    感觉要做出来这个题,需要一定的线代芝士 首先,我们来观察这个柿子. 我们将\(B\)的权值看作是收益的话,\(C\)的权值就是花费. 根据矩阵乘法的原理,只有当\(a[i]和a[j]\)都为\(1\) ...

  9. CF992E Nastya and King-Shamans(线段树二分+思维)

    这是一道卡常好题 从160s卡到36s qwq 由于题目设计到原数组的单点修改,那么就对应着前缀和数组上的区间加. 很显然能想到用线段树来维护这么个东西. 那么该如果求题目要求的位置呢 我们来看这个题 ...

  10. C#并行编程:Parallel的使用

    前言:在C#的System.Threading.Tasks 命名空间中有一个静态的并行类:Parallel,封装了Task的使用,对于执行大量任务提供了非常简便的操作.下面对他的使用进行介绍. 本篇内 ...