逆序数技巧 - 牛客

链接:https://ac.nowcoder.com/acm/contest/308/D
来源:牛客网

题目描述

tokitsukaze给你一个长度为n的序列,这个序列是1到n的一种排列。
然后她会进行q次操作。每次操作会给你L R k这三个数,表示区间[L,R]往右移动k次。
移动一次的定义是:一个数的位置是P(L≤P≤R-1),它往右移动后就会在P+1这个位置上;如果一个数在R这个位置,它会移动到L这个位置。
在每次操作结束后,tokitsukaze想让你算出现在这个序列的逆序数的多少,简单起见,你只需要告诉她现在这个序列的逆序数是奇数还是偶数就行了。
提示:序列的逆序数指的是:a[i]>a[j](i<j),满足条件的(i,j)的个数。

输入描述:

第一行包括一个正整数n(1≤n≤10^5)。
接下来一行,包括一个长度为n的序列,序列为1到n的一种排列。
第三行包括一个正整数q(1≤q≤10^5)。
接下来q行,每行包括三个正整数L,R,k(1≤L≤R≤n,1≤k≤10^9)。
所有变量的含义题面均有给出。

输出描述:

在每次操作后,逆序数如果是奇数,就输出1,如果是偶数,就输出0。
示例1

输入

复制
4
2 3 1 4
3
1 3 2
2 4 1
2 3 1

输出

复制
0
0
1

说明

原序列为:2 3 1 4
第一次操作后,序列变为:3 1 2 4,逆序数为2,所以答案为0。
第二次操作后,序列变为:3 4 1 2,逆序数为4,所以答案为0。
第三次操作后,序列变为:3 1 4 2,逆序数为3,所以答案为1。

题意 : 每次选择一个区间循环变换, 求整个串的逆序数是奇数还是偶数
思路分析 :
  首先可以很容易求出整个序列的逆序数是多少,然后循环移位某一个区间时,会有个小特点就是,移动一步时,逆序数变化只会取决于他前面可操作区间的长度,,若其为偶数,则逆序数的奇偶不会发生变化,否则会产生变化。

代码示例 :
  
int n;
int a[maxn];
int l, r, k;
int c[maxn];
int lowbit(int x){return x&(-x);}
void add(int pos){for(int i = pos; i <= n; i += lowbit(i)){c[i] += 1;}
}
int query(int pos){int res = 0;for(int i = pos; i ; i -= lowbit(i)){res += c[i];}return res;
}
int ans = 0;
void solve() {for(int i = 1; i <= n; i++){add(a[i]);ans += i-query(a[i]);ans = ans&1;}
}int main() {//freopen("in.txt", "r", stdin);//freopen("out.txt", "w", stdout);cin >> n;for(int i = 1; i <= n; i++) scanf("%d", &a[i]);int q;solve();//printf("+++++ %d \n", ans);cin >> q;while(q--){scanf("%d%d%d", &l, &r, &k);k = k % (r-l+1);int len = (r-l)*k;if (len&1) ans += 1;ans = ans&1;printf("%d\n", ans);}return 0;
}

 


  

转载于:https://www.cnblogs.com/ccut-ry/p/10087216.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/276737.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Ajax跨域提交JSON和JSONP

可以直接使用$.getJSON()方法实现跨域请求&#xff0c;参数中必须加上callback&#xff0c;如&#xff1a; var jsonpUrl http://www.test.com/index.php?cApi_Order&aAddOrder&callback?;var param {uid:uid,type:type,cityId:cityId};$.getJSON(jsonpUrl, param,…

mysql数据库商业版与社区版的区别

1、商业版本组织管理与测试环节控制更严格&#xff0c;稳定性方面&#xff0c;会比社区版本更稳定。 2、mysql是成熟产品&#xff0c;商业版与社区版之间性能方面相差不大。 3、商业版不遵守GPL协议&#xff0c;社区版遵守GPL协议可以免费使用。 4、使用商业版后可以购买相关的…

UML的奥妙 - 学习UML笔记(1)

前两天买了一本《大象 Thinking in UML》&#xff0c;其实本就有学习UML的念头&#xff0c;但都因这样那样的事儿耽搁了&#xff0c;当然&#xff0c;也有些惰性在作祟...... 闲话少说&#xff0c;这本书看完了一章&#xff0c;发现还是不错的&#xff0c;先把这两天的学习情况…

无法检查指定的位置是否位于cfs上_(干货分享)一文搞明白 节气门位置传感器的作用、故障类型与症状、诊断方法...

1 位置节气门位置传感器(ThrottlePositionSensor&#xff0c;TPS)&#xff0c;位于节气门体上&#xff0c;其安装形式因节气门结构的不同而有所差异&#xff1a;对于传统的机械拉索式节气门&#xff0c;节气门位置传感器通常以一个独立元件的形式安装在节气门体的侧面&#xf…

盒子模型

1 <!doctype html>2 <html>3 <head>4 <title>盒子模型</title>5 <meta charset"utf-8">6 <meta name"keywords", content"">7 <meta name"description&…

表单跨域提交

利用form表单跨域post 现在ajax应用这么广泛&#xff0c;一般的应用都是直接通过异步调用就可以了&#xff0c;但是有些东西必须要使用post&#xff0c;而且是跨域的时候&#xff0c;ajax异步调用的方式就无能为力了。当然现在也有很多种办法&#xff0c;比如通过flash中转去po…

Asp.net(C#)-显示所有缓存 清除所有缓存

//清除所有缓存protectedvoidRemoveAllCache() { System.Web.Caching.Cache _cache HttpRuntime.Cache; IDictionaryEnumerator CacheEnum _cache.GetEnumerator(); ArrayList al new ArrayList(); while (CacheEnum.MoveNext()) { …

mysql数据库三大引擎优缺点

1.MyISAM 特性&#xff1a; ①不支持事务。 ②表级锁定&#xff0c;并发性能大大降低。 ③读写互相阻塞。 适用场景&#xff1a; ①不支持事务。 ②并发相对较低&#xff0c;表锁定。 ③执行大量select语句操作的表。 ④count(*)操作较快。 ⑤不支持外键。 注&#xff1a;查询速…

Python--day60--一个简单(不完整)的web框架

转载于:https://www.cnblogs.com/xudj/p/10091775.html

activemq 发两条只收到一条_浅谈ActiveMQ与使用

更多大数据架构、实战经验&#xff0c;欢迎关注【大数据每日哔哔】&#xff0c;期待与你一起成长&#xff01;本文将介绍一下 ActiveMQ 的安装、原理和简单实战。一、什么是消息中间件消息中间件顾名思义实现的就是在两个系统或两个客户端之间进行消息传送二、什么是ActiveMQAc…

php发送get、post请求的几种方法

方法1: 用file_get_contents 以get方式获取内容 <?php $urlhttp://www.domain.com/; $html file_get_contents($url); echo $html; ?>方法2: 用fopen打开url, 以get方式获取内容<?php $fp fopen($url, r); stream_get_meta_data($fp); while(!feof($fp)) { $res…

ZZ:深入理解new

new的过程当我们使用关键字new在堆上动态创建一个对象时&#xff0c;它实际上做了三件事&#xff1a;获得一块内存空间、调用构造函数、返回正确的指针。当然&#xff0c;如果我们创建的是简单类型的变量&#xff0c;那么第二步会被省略。假如我们定义了如下一个类A&#xff1a…

mysql数据库的优缺点

优点1. 通常存储过程 标题有助于提高应用程序的性能。因为当你创建他的时候就已经编译了&#xff0c;只不过是按需编译的。2.存储过程有助于减少应用程序和数据库服务器之间的流量&#xff0c;因为应用程序不必发送多个冗长的SQL语句&#xff0c;而只能发送存储过程的名称和参数…

大数据小白系列——HDFS(1)

【注1&#xff1a;结尾有大福利&#xff01;】 【注2&#xff1a;想写一个大数据小白系列&#xff0c;介绍大数据生态系统中的主要成员&#xff0c;理解其原理&#xff0c;明白其用途&#xff0c;万一有用呢&#xff0c;对不对。】 大数据是什么&#xff1f;抛开那些高大上但笼…

PHP检测远端文件是否存在

简单解释一下上面的代码。get_headers的作用就是访问一个远程地址&#xff0c;把服务器发送的HTTP头以数组形式返回。而$header[0]则是服务器返回的状态码&#xff08;如果不出意外的话状态码应该都是第一个返回的&#xff09;。 要确定一个文件在远端服务器上存在&#xff0c…

C#中使用DTS来导入数据及相关问题

向Sql 中导入Excel数据时&#xff0c;使用MS SQL的DTS功能 可以很方便的导入&#xff0c;同时引用Dll文件&#xff0c;可以在程序中对导入过程进行控制。 创建DTS包的过程如下&#xff1a; &#xff11;。在&#xff33;&#xff31;&#xff2c;企业管理器中&#xff0c;工具菜…

html select选择事件_一道搜狗面试题:IO多路复用中select、poll、epoll之间的区别...

(1)select>时间复杂度O(n)它仅仅知道了&#xff0c;有I/O事件发生了&#xff0c;却并不知道是哪那几个流(可能有一个&#xff0c;多个&#xff0c;甚至全部)&#xff0c;我们只能无差别轮询所有流&#xff0c;找出能读出数据&#xff0c;或者写入数据的流&#xff0c;对他们…

【MySQL】redo log --- 刷入磁盘过程

1、redo log基本概念 redo log的相关概念这里就不再过多阐述&#xff0c;网上有非常多的好的资料&#xff0c;可以看下缥缈大神的文章&#xff1a;https://www.cnblogs.com/cuisi/p/6525077.html&#xff0c;个人感觉介绍的非常详细。 2、数据更改过程简述 MySQL 在更新数据的时…

WPF DataGrid根据内容设置行颜色

转&#xff1a; https://code.4noobz.net/wpf-change-color-of-a-row-in-a-datagrid-depending-on-the-value/ 转载于:https://www.cnblogs.com/Mindy-hym/p/11475024.html

QQ web api

QQ的很多功能和信息可以通过web方式获得&#xff5e;以下链接&#xff0c;星号应换成你要查询的QQ号一、Activities Previewhttp://labs.qq.com/ie8/preview/?uin******二、QQ空间访问次数查询&#xff08;需权限&#xff09;http://g.qzone.qq.com/fcg-bin/cgi_emotion_list.…