17.3.18 数据结构 校内赛(rotinv)(rise)

2024-03-28 15:08

本文主要是介绍17.3.18 数据结构 校内赛(rotinv)(rise),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这套题是知名的idy002出的,我们来看看题:

1.rotinv


【解题报告】
这道题是这样一个思路:
首先我们需要将[1,n]的数组开一个镜像,在[n+1,2n]的空间存储相同的内容。我们先算出[1,n]之内的逆序对个数,之后将这个区间向右移动,算出这个新的区间的逆序对个数(这样做就可以穷尽所有的组合情况),之后输出就可以了。
那么我们用什么办法算出一个区间的逆序对个数呢?我们从左到右枚举每一个数,找出比这个数大的数累加个数就可以了。
那么怎么维护这样一个区间的答案呢?我们算出了[i,j]过后,右移一位即是[i+1,j+1],我们只需要把[i+1,j]中比a[j+1]大的数,再减去[i+1,j]中比a[i]小的个数(实质上就是把比原来的右端点小的减去,把比现在的右端点大的加上)。再把这样一个值同[i,j]的值加起来。
此外再用树状数组优化。
来看看代码:

#include<cstdio>
#include<iostream>
using namespace std;
const int N = 1000000 + 10;
template<class T>inline void readin(T &resez)//读入优化 
{static char ch;while((ch=getchar())<'0'||ch>'9');resez=ch-48;while((ch=getchar())>='0'&&ch<='9')resez=resez*10+ch-48;
}
int n;
int a[N+N];
int bit[N*24];
long long ans,cnt;
void build(int pos,int delta)//在树状数组中添加 
{for(register int i=pos;i<=n;i+=i&-i)bit[i]+=delta;
}
int query(int right)//树状数组中求和 
{int rt=0;for(register int i=right;i;i-=i&-i)rt+=bit[i];return rt;
}
int main() {freopen("rotinv.in","r",stdin);freopen("rotinv.out","w",stdout);readin(n);for(register int i=1;i<=n;i++) {readin(a[i]);a[n+i]=a[i];}for(register int i=1;i<=n;i++){cnt+=(i-1)-query(a[i]);build(a[i],+1);}//这时cnt中存储的是[1,n]中的逆序对个数 for(register int i=n+1;i<=n+n;i++)//这里就将a[1,n]的区间向右移,减去比a[i-n](原右端点)小的,加上比a[i](现右端点)大的 {build(a[i-n],-1);cnt+=n-1-query(a[i]);//比a[i]大的数 cnt-=query(a[i-n]-1);//比a[i-n]小的数 build(a[i],+1);ans+=cnt;}printf("%d",ans);return 0;
}

2.rise


【解题报告】
这道题有两种解法,一种是用线段树(此处略),另一种是通过搞一个类似于“链表”的结构,将某一柱子向右离他最近的那个柱子标记好。最后查询时按照我构造的这个路径即可。

#include<cstdio>
#include<iostream>
#define N 100010
using namespace std;
template<class T>inline void read(T &res)//读入优化 
{static char ch;while((ch=getchar())<'0'||ch>'9');res=ch-48;while((ch=getchar())>='0'&&ch<='9')res =ch-48+res*10;
}
int later[N];
int a[N];
int main()
{freopen("rise.in","r",stdin);freopen("rise.out","w",stdout);int n,q;read(n),read(q);for(register int i=1;i<=n;i++)read(a[i]);for(register int i=1;i<=n;i++)for(register int j=i+1;j<=n;j++)if (a[j]>a[i])//(预处理)暴力枚举找到数组中比a[i]大的最近的那个数 {later[i]=j;break;      }while(q--){int l,r;read(l),read(r);int p=l;int tot=0;while(p<=r&&p!=0)//这里从l开始,依据预处理的路径来计数 {tot++;p=later[p];}printf("%d\n",tot);}
}

以上
2017.3.23

这篇关于17.3.18 数据结构 校内赛(rotinv)(rise)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/855952

相关文章

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

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

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)

《数据结构(C语言版)第二版》第八章-排序(8.3-交换排序、8.4-选择排序)

8.3 交换排序 8.3.1 冒泡排序 【算法特点】 (1) 稳定排序。 (2) 可用于链式存储结构。 (3) 移动记录次数较多,算法平均时间性能比直接插入排序差。当初始记录无序,n较大时, 此算法不宜采用。 #include <stdio.h>#include <stdlib.h>#define MAXSIZE 26typedef int KeyType;typedef char In

【408数据结构】散列 (哈希)知识点集合复习考点题目

苏泽  “弃工从研”的路上很孤独,于是我记下了些许笔记相伴,希望能够帮助到大家    知识点 1. 散列查找 散列查找是一种高效的查找方法,它通过散列函数将关键字映射到数组的一个位置,从而实现快速查找。这种方法的时间复杂度平均为(

浙大数据结构:树的定义与操作

四种遍历 #include<iostream>#include<queue>using namespace std;typedef struct treenode *BinTree;typedef BinTree position;typedef int ElementType;struct treenode{ElementType data;BinTree left;BinTre

Python 内置的一些数据结构

文章目录 1. 列表 (List)2. 元组 (Tuple)3. 字典 (Dictionary)4. 集合 (Set)5. 字符串 (String) Python 提供了几种内置的数据结构来存储和操作数据,每种都有其独特的特点和用途。下面是一些常用的数据结构及其简要说明: 1. 列表 (List) 列表是一种可变的有序集合,可以存放任意类型的数据。列表中的元素可以通过索

浙大数据结构:04-树7 二叉搜索树的操作集

这道题答案都在PPT上,所以先学会再写的话并不难。 1、BinTree Insert( BinTree BST, ElementType X ) 递归实现,小就进左子树,大就进右子树。 为空就新建结点插入。 BinTree Insert( BinTree BST, ElementType X ){if(!BST){BST=(BinTree)malloc(sizeof(struct TNo

【数据结构入门】排序算法之交换排序与归并排序

前言         在前一篇博客,我们学习了排序算法中的插入排序和选择排序,接下来我们将继续探索交换排序与归并排序,这两个排序都是重头戏,让我们接着往下看。  一、交换排序 1.1 冒泡排序 冒泡排序是一种简单的排序算法。 1.1.1 基本思想 它的基本思想是通过相邻元素的比较和交换,让较大的元素逐渐向右移动,从而将最大的元素移动到最右边。 动画演示: 1.1.2 具体步

react笔记 8-18 事件 方法 定义方法 获取/改变数据 传值

1、定义方法并绑定 class News extends React.Component {constructor(props) {super(props)this.state = {msg:'home组件'}}run(){alert("我是一个run") //方法写在类中}render() {return (<div><h2>{this.state.msg}</h2><button onCli

数据结构:线性表的顺序存储

文章目录 🍊自我介绍🍊线性表的顺序存储介绍概述例子 🍊顺序表的存储类型设计设计思路类型设计 你的点赞评论就是对博主最大的鼓励 当然喜欢的小伙伴可以:点赞+关注+评论+收藏(一键四连)哦~ 🍊自我介绍   Hello,大家好,我是小珑也要变强(也是小珑),我是易编程·终身成长社群的一名“创始团队·嘉宾” 和“内容共创官” ,现在我来为大家介绍一下有关物联网-嵌入