有趣的家庭菜园

题目链接https://lydsy.com/JudgeOnline/problem.php?id=4240

数据范围:略。


题解

第一步比较简单,只需要排序之后,每个数不是在左边就是在右边。

我们只需要计算出,当前这个数如果在左边,能跟没放进数列的数构成的逆序对数和在右边哪个更小。

这个过程可以用树状数组维护。

代码

  1. #include <bits/stdc++.h>
  2.  
  3. #define N 1000010
  4.  
  5. using namespace std;
  6.  
  7. typedef long long ll;
  8.  
  9. char *p1, *p2, buf[100000];
  10.  
  11. #define nc() (p1 == p2 && (p2 = (p1 = buf) + fread(buf, 1, 100000, stdin), p1 == p2) ? EOF : *p1 ++ )
  12.  
  13. int rd() {
  14. int x = 0, f = 1;
  15. char c = nc();
  16. while (c < 48) {
  17. if (c == '-')
  18. f = -1;
  19. c = nc();
  20. }
  21. while (c > 47) {
  22. x = (((x << 2) + x) << 1) + (c ^ 48), c = nc();
  23. }
  24. return x * f;
  25. }
  26.  
  27. int tr[N];
  28.  
  29. inline int lowbit(int x) {
  30. return x & (-x);
  31. }
  32.  
  33. void upd(int x, int val) {
  34. for (int i = x; i < N; i += lowbit(i)) {
  35. tr[i] += val;
  36. }
  37. }
  38.  
  39. int qry(int x) {
  40. int ans = 0;
  41. for (int i = x; i; i -= lowbit(i)) {
  42. ans += tr[i];
  43. }
  44. return ans;
  45. }
  46.  
  47. struct Node {
  48. int val, id;
  49. }a[N];
  50.  
  51. inline bool cmp(const Node &a, const Node &b) {
  52. return a.val > b.val;
  53. }
  54.  
  55. int main() {
  56. int n = rd();
  57. for (int i = 1; i <= n; i ++ ) {
  58. a[i].val = rd(), a[i].id = i;
  59. }
  60. ll ans = 0;
  61. sort(a + 1, a + n + 1, cmp);
  62. for (int i = 1; i <= n; ){
  63. int j;
  64. for (j = i; j <= n; j ++ ) {
  65. int mdl = qry(a[j].id);
  66. ans += min(mdl, i - 1 - mdl);
  67. if (a[j + 1].val != a[j].val) {
  68. break;
  69. }
  70. }
  71. for (; i <= j; i ++ ) {
  72. upd(a[i].id, 1);
  73. }
  74. }
  75.  
  76. cout << ans << endl ;
  77. return 0;
  78. }

[bzoj4240]有趣的家庭菜园_树状数组的更多相关文章

  1. [BZOJ4240]有趣的家庭菜园(贪心+树状数组)

    最后数列一定是单峰的,问题就是最小化最后的位置序列的逆序对数. 从大到小加数,每次贪心看放左边和右边哪个产生的逆序对数更少,树状数组即可. 由于大数放哪对小数不产生影响,所以正确性显然. 注意相同数之 ...

  2. 【bzoj4240】有趣的家庭菜园 贪心+树状数组

    题目描述 对家庭菜园有兴趣的JOI君每年在自家的田地中种植一种叫做IOI草的植物.JOI君的田地沿东西方向被划分为N个区域,由西到东标号为1~N.IOI草一共有N株,每个区域种植着一株.在第i个区域种 ...

  3. bzoj 4240: 有趣的家庭菜园【树状数组+贪心】

    以为是逆序对数-- 实际上,原数组移动若干次后我们会得到一个新的下标序列,需要的移动次数是这个新下标序列的逆序对数 然后我们要让这个最小,考虑贪心先按h把下标排一遍序,然后每次询问到一种值的时候,对每 ...

  4. BZOJ_5055_膜法师_树状数组+离散化

    BZOJ_5055_膜法师_树状数组+离散化 Description 在经历过1e9次大型战争后的宇宙中现在还剩下n个完美维度, 现在来自多元宇宙的膜法师,想偷取其中的三个维度为伟大的长者续秒, 显然 ...

  5. BZOJ_3653_谈笑风生_树状数组

    BZOJ_3653_谈笑风生_树状数组 Description 设T 为一棵有根树,我们做如下的定义: ? 设a和b为T 中的两个不同节点.如果a是b的祖先,那么称“a比b不知道 高明到哪里去了”. ...

  6. BZOJ_3196_Tyvj 1730 二逼平衡树_树状数组套主席树

    BZOJ_3196_Tyvj 1730 二逼平衡树_树状数组套主席树 Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: 1.查询k在区间内的排 ...

  7. BZOJ_2141_排队_树状数组+分块

    BZOJ2141_排队_树状数组+分块 Description 排排坐,吃果果,生果甜嗦嗦,大家笑呵呵.你一个,我一个,大的分给你,小的留给我,吃完果果唱支歌,大家 乐和和.红星幼儿园的小朋友们排起了 ...

  8. BZOJ_3132_上帝造题的七分钟_树状数组

    BZOJ_3132_上帝造题的七分钟_树状数组 Description “第一分钟,X说,要有矩阵,于是便有了一个里面写满了0的n×m矩阵. 第二分钟,L说,要能修改,于是便有了将左上角为(a,b), ...

  9. bzoj4240: 有趣的家庭菜园(树状数组+贪心思想)

    4240: 有趣的家庭菜园 题目:传送门 题解: 好题!%%% 一开始不知道在想什么鬼,感觉满足二分性?感觉可以维护一个先单调增再单调减的序列? 然后开始一顿瞎搞...一WA 看一波路牌...树状数组 ...

随机推荐

  1. 《挑战30天C++入门极限》 对C++中引用的补充说明(实例)

        对C++中引用的补充说明(实例) #include <iostream>    #include <string>    using namespace std;    ...

  2. GAN 原理及公式推导

    Generative Adversarial Network,就是大家耳熟能详的 GAN,由 Ian Goodfellow 首先提出,在这两年更是深度学习中最热门的东西,仿佛什么东西都能由 GAN 做 ...

  3. 清理Windows.edb

    解决Windows.edb文件巨大的windows 10问题的另一个快速解决方法是删除Windows.edb文件. 步骤1:在任务管理器中终止SearchIndexer.exe --按Ctrl + A ...

  4. vim 外部粘贴代码,如何保持原格式,而不持续缩进

    主要内容:使用“:set paste” 来实现vim 按照源文件格式复制 在vim 使用中偶尔要复制外部代码,常常出现不停缩进的问题: 怎么避免此种情况出现呢 可以在命令模式中使用“:set past ...

  5. java/spring boot/dubbo/spring cloud/微服务/SOA/分布式经典电子书籍pdf下载

    微服务系列 官方文档是最好的资料了. spring cloud官方文档:https://cloud.spring.io/spring-cloud-static/Greenwich.RELEASE/si ...

  6. 京东HBase平台进化与演进

    https://mp.weixin.qq.com/s/7_dxrqFWwIJxNtL9-xD6FA

  7. 深入浅出ES6教程『async函数』

    大家好,本人名叫苏日俪格,大家叫我 (格格) 就好,在上一章节中我们学到了Symbol & generator的用法,下面我们一起来继续学习async函数: async [ə'zɪŋk]:这个 ...

  8. Linux_CentOS 文件管理和目录管理

    Linux 文件管理 1.创建文件 touch file1 2.删除文件 rm -rf file11 -r:递归的删除目录下面文件以及子目录下文件. -f:强制删除,忽略不存在的文件,从不给出提示 3 ...

  9. flutter手势

    import 'package:flutter/material.dart'; import 'package:flutter_app/pages/dismissed_page.dart'; clas ...

  10. ISO/IEC 9899:2011 条款6.7——声明

    6.7 声明 语法 1.declaration: declaration-specifiers    init-declarator-listopt    ; static_assert-declar ...