题意
给出一列n个数字,每一个数字都和其他数字不同,现在每次都把第一个数挪到最后面,求这个过程中这个数列逆序数对最少有多少对。
思路
先用线段树求出初始的数列逆序对数,再用第一个数列推出第二个,第三个直到第n个,输出最小的那个
这里关键是线段树在lonn的时间复杂度内求出当前数列逆序数对的方法,每次插入一个数,num[i] ,都查询一遍在num[i]+1---n中存在多少个已经插入的点。
#include<iostream> #include<cstdio> #include<cstring> using namespace std; const int nMax = 6000; struct{ int l,r,val; }node[nMax*4]; int num[nMax]; void build(int l, int r, int u){ //建树 node[u].val = 0; node[u].l=l; node[u].r=r; if(l == r){ return; } int m = (l+r)/2; build(l , m ,u*2); build(m+1 , r, u*2 + 1); } void update(int p,int u){ //更新 int l = node[u].l; int r = node[u].r; if(l == r){ num[u]++; }else{ int m = (l + r)>>1 ; if( p <= m ){ update(p , u*2) ; }else{ update (p ,u * 2 + 1) ; } num[u] = ( num[u*2] + num[u*2+1]) ; } } int query(int le ,int ri ,int u){ //查询 int l = node[u].l; int r = node[u].r; if(le <= l && r <= ri ){ return num[u]; } int m = ( l + r ) >> 1 , res = 0 ; if(ri >= m + 1 ){ res += query(le , ri ,u * 2 + 1 ); } if( le <= m ){ res += query(le , ri , u * 2 ); } return res; } int ipt[nMax]; int main(){ int n , i, j ,a ,b ,c , sum ; while(scanf("%d",&n)!=EOF){ sum = 0; memset(num , 0, sizeof(num)); build(0 , n-1, 1); for(i = 0; i < n ; i++){ scanf("%d",&ipt[i]); update( ipt[i] ,1); sum += query(ipt[i] + 1 , n-1 , 1); } int ans = sum ; // cout<<ans<<endl; for(i = 0 ;i < n ; i++ ){ sum = sum - 2 * ipt[i] + n -1 ; ans = min(ans , sum); } printf("%d\n",ans); } return 0; }
#include<iostream> #include<cstdio> #include<cstring> using namespace std; const int nMax = 6000; struct{ int l,r,val; }node[nMax*4]; int num[nMax]; void build(int l, int r, int u){ //建树 node[u].val = 0; node[u].l=l; node[u].r=r; if(l == r){ return; } int m = (l+r)/2; build(l , m ,u*2); build(m+1 , r, u*2 + 1); } void update(int p,int u){ //更新 int l = node[u].l; int r = node[u].r; if(l == r){ num[u]++; }else{ int m = (l + r)>>1 ; if( p <= m ){ update(p , u*2) ; }else{ update (p ,u * 2 + 1) ; } num[u] = ( num[u*2] + num[u*2+1]) ; } } int query(int left, int right, int u){ // 查询。 if(node[u].l == left && node[u].r == right) return num[u]; if(right <= node[2*u].r) return query(left, right, 2*u); if(left >= node[2*u+1].l) return query(left, right, 2*u+1); int a = query(left, (node[u].l+node[u].r)/2, 2*u); int b = query((node[u].l+node[u].r)/2+1, right, 2*u+1); return a + b; } int ipt[nMax]; int main(){ int n , i, j ,a ,b ,c , sum ; while(scanf("%d",&n)!=EOF){ sum = 0; memset(num , 0, sizeof(num)); build(0 , n-1, 1); for(i = 0; i < n ; i++){ scanf("%d",&ipt[i]); sum += query(ipt[i], n-1 , 1); update( ipt[i] ,1); } int ans = sum ; // cout<<ans<<endl; for(i = 0 ;i < n ; i++ ){ sum = sum - 2 * ipt[i] + n -1 ; ans = min(ans , sum); } printf("%d\n",ans); } return 0; }
相关推荐
例如,在HDOJ 1166题中,使用线段树来解决敌兵布阵问题。在这个问题中,需要快速地进行点修改和区间查询操作,而线段树正好满足这个需求。 线段树的优缺点 线段树的优点是:1. 高效的查询速度:线段树能够快速地...
例如,HDOJ 1166题目的解决方案就展示了如何用线段树处理区间求和的问题。 2. **节点结构**: 线段树的每个节点通常包含三个属性:左边界(l),右边界(r)和中间值(mid,表示当前节点覆盖的区间的中间位置)。...
6. **搜索算法**:包括深度优先搜索(DFS)和广度优先搜索(BFS),是解决图论问题和树结构问题的重要工具。课件中会介绍它们的工作原理以及如何在实际问题中应用。 7. **组合博弈论**:这是博弈论的一个分支,研究...
而`hdoj`可能指的是HDU(杭州电子科技大学)在线判题系统的题目,这些题目涵盖了各种ACM算法,可以作为练习和检验理解的平台。 总之,这个资源包是学习和提升ACM算法技能的理想材料,通过深入学习和实践,你可以...
免费的防止锁屏小软件,可用于域统一管控下的锁屏机制
内容概要:本文介绍了一段简单的Python代码,用于在控制台中输出一棵带有装饰的圣诞树。具体介绍了代码结构与逻辑,包括如何计算并输出树形的各层,如何加入装饰元素以及打印树干。还提供了示例装饰字典,允许用户自定义圣诞树装饰位置。 适用人群:所有对Python编程有一定了解的程序员,尤其是想要学习控制台图形输出的开发者。 使用场景及目标:适用于想要掌握如何使用Python代码创建控制台艺术,特别是对于想要增加节日氛围的小项目。目标是帮助开发者理解和实现基本的字符串操作与格式化技巧,同时享受创造乐趣。 其他说明:本示例不仅有助于初学者理解基本的字符串处理和循环机制,而且还能激发学习者的编程兴趣,通过调整装饰物的位置和树的大小,可以让输出更加个性化和丰富。
白色大气风格的设计师作品模板下载.zip
电商平台开发需求文档.doc
白色简洁风格的办公室室内设计门户网站模板下载.zip
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于计算机科学与技术等相关专业,更为适合;
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于计算机科学与技术等相关专业,更为适合;
课程设计---基于Android stduio的手机银行开发与设计 现今,手机已经成为人们生活和工作的必备品,在手机各种系统中Android系统是人们用的比较多的系统。手机银行也是人们在生活中比较常用的功能之一。本项目基于Android的手机银行开发与设计主要功能有登录注册、转账、转账记录查询、修改及查询个人信息、添加好友、向好友转账的功能。本项目主要用Android Studio 开发,数据库SQLite数据库,和夜神模拟器。 基于Android stduio的手机银行开发与设计项目主要功能有登录注册、转账、转账记录查询、修改及查询个人信息、添加好友、向好友转账的功能。。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。
白色大气风格的婚礼现场倒计时模板下载.zip
轮式移动机器人轨迹跟踪的MATHLAB程序,运用运动学和动力学模型的双闭环控制,借鉴自抗扰控制技术结合了非线性ESO,跟踪效果良好,控制和抗扰效果较优,可分享控制结构图。 这段程序主要是一个小车的动力学仿真程序,用于模拟小车在参考轨迹下的运动。下面我将对程序进行详细的分析解释。 首先,程序开始时使用`clear`、`clc`和`close all`命令来清除工作空间、命令窗口和图形窗口中的内容。 接下来,程序定义了一系列参数和变量,用于设置仿真的参数和存储仿真过程中的数据。这些参数包括小车的质量、车宽、驱动轮半径等,还有参考轨迹的振幅和频率,仿真步长,仿真时间等。 然后,程序定义了一些元胞数组,用于存储不同阶段的数据。这些数组包括参考轨迹位姿、真实运动轨迹位姿、参考轨迹一阶导数、参考轨迹速度、期望速度、真实速度、控制器输出的控制力矩、控制输入、期望速度与真实速度误差、摩擦值、外界扰动值、总扰动、位姿跟踪误差、扰动观测值等。 接下来,程序给这些变量赋初始值,包括小车的初始位姿和速度,初始速度,期望初始速度,控制器输出的控制力矩,扰动观测值等。 然后,程序进入一个循环,仿真时间从
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于计算机科学与技术等相关专业,更为适合;
这是一份来自开源的全球新冠肺炎数据集,每日时间序列汇总,包括确诊、死亡和治愈。所有数据来自每日病例报告。数据持续更新中。 由于数据集中没有美国的治愈数据,所以在统计全球的现有确诊人员和治愈率的时候会有很大误差,代码里面先不做这个处理,期待数据集的完善。
白色大气风格的时装设计公司模板下载.zip
白色大气风格的商务会议活动模板下载.rar
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于计算机科学与技术等相关专业,更为适合;
本次开发一套基于微信小程序的生签到系统,有管理员,教师,学生三个角色。管理员功能有个人中心,学生管理,教师管理,签到管理,学生签到管理,班课信息管理,加入班课管理,请假信息管理,审批信息管理,销假信息管理,系统管理。教师和学生都可以在微信端注册和登录,教师可以管理签到信息,管理班课信息,审批请假信息,查看学生签到,查看加入班级,查看审批信息和销假信息。学生可以查看教师发布的学生签到信息,可以自己选择加入班课信息,添加请假信息,查看审批信息,进行销假操作。基于微信小程序的生签到系统服务端用Java开发的网站后台,接收并且处理微信小程序端传入的json数据,数据库用到了MySQL数据库作为数据的存储。