每日一题冲刺大厂第十七天 逆序对

简介: 大家好,我是泡泡,给大家带来每日一题的目的是为了更好的练习算法,我们的每日一题为了让大家练到各种各样的题目,熟悉各种题型,一年以后,蜕变成为一个不一样的自己!

今日题目: 逆序对


题目描述


猫猫 TOM 和小老鼠 JERRY 最近又较量上了,但是毕竟都是成年人,他们已经不喜欢再玩那种你追我赶的游戏,现在他们喜欢玩统计。


最近,TOM 老猫查阅到一个人类称之为“逆序对”的东西,这东西是这样定义的:对于给定的一段正整数序列,逆序对就是序列中 ai>aj 且 i


Update:数据已加强。


输入格式


第一行,一个数 n,表示序列中有 n个数。


第二行 n 个数,表示给定的序列。序列中每个数字不超过 10^9。


输出格式


输出序列中逆序对的数目。


题目分析


题目难度:⭐️⭐️


题目涉及算法:树状数组,排序。


ps:有能力的小伙伴可以尝试优化自己的代码或者一题多解,这样能综合提升自己的算法能力


题解报告:


1.思路


可以用树状数组,逆序对板子解决这个问题,如果不懂的话可以去学习一下逆序对或者树状数组。


2.代码


#include <bits/stdc++.h>
using namespace std;
int n,a[5000002],b[5000002];
long long num=0;
void merge(int l,int r)
{
  int mid = (l+r)/2;
  if(l == r)
  {
    return ;
  }
  else
  {
    merge(l,mid); 
    merge(mid+1,r);
  }
  int i = l;
  int j = mid + 1;
  int t = l;
  while(i<=mid&&j<=r)
  {
    if(a[i]>a[j]) 
    { 
      num += mid - i + 1;
      b[t++] = a[j];
      j++;
    }
    else
    {
      b[t++] = a[i];
      i++;
    }
  }
  while(i<=mid)
  {
    b[t++] = a[i];
    i++; 
  }
  while(j<=r)
  {
    b[t++]=a[j];
    j++;
  }
  for(int i=l;i<=r;i++)
  {
    a[i] = b[i];
  }
  return ;
}
int main()
{
  cin>>n;
  for(int i=1;i<=n;i++)
  {
    cin>>a[i];
  }
  merge(1, n);
  printf("%lld",num);
  return 0;
}


目录
相关文章
|
9月前
|
存储 算法
【随想】每日两题Day.20(实则一题)
【随想】每日两题Day.20(实则一题)
49 0
|
9月前
【随想】每日两题Day.16(实则一题)
【随想】每日两题Day.16(实则一题)
50 0
|
9月前
【随想】每日两题Day.5 (实则一题)
【随想】每日两题Day.5
38 0
|
9月前
【随想】每日两题Day.3(实则一题)
【随想】每日两题Day.3
39 0
|
9月前
|
存储
【随想】每日两题Day.10(实则一题)
【随想】每日两题Day.10(实则一题)
44 0
|
9月前
|
C语言
青蛙跳台阶:我如何得知它是一道斐波那契数列题?——应用题破题“三板斧”(一)
这篇内容介绍了C语言学习中的经典例题——斐波那契数列,强调了解题思路的重要性。斐波那契数列是一个数列,其中每个数是前两个数的和。文章指出,很多类似题目,如“青蛙跳台阶”,实质上都在考察斐波那契数列的实现。文中提供了斐波那契数列的定义、代码实现和递归与非递归的思路,并鼓励读者从问题中分析出解题模型,而非直接套用已知方法。此外,还提及了一道相关题目“矩形覆盖问题”,以供进一步练习。
80 0
|
9月前
|
机器学习/深度学习 算法 测试技术
青蛙跳台阶:我如何得知它是一道斐波那契数列题?——应用题破题“三板斧”(二)
这篇内容是关于解题策略的,主要介绍了在面对应用题时可以采用的“三板斧”方法:举例、模拟和找规律。通过一个走楼梯的例子详细解释了这三个步骤如何运用。首先,举例将抽象问题具体化,比如走5级台阶有几种方式。其次,通过模拟不同情况,例如思考走每一步的可能,发现递归或循环的模式。最后,通过找规律归纳出一般性的解决方案,这里发现走台阶问题与斐波那契数列相关。文章还提到了一个拓展案例——矩形覆盖问题,同样可以用类似的方法分析。总的来说,文章强调了解题过程中理解和转化问题的重要性,以及通过训练提升这方面能力。
72 0
|
9月前
|
算法
再探二分法
【2月更文挑战第5天】
80 3
|
9月前
蓝桥备战--分糖果OJ2928 贪心 分类讨论
蓝桥备战--分糖果OJ2928 贪心 分类讨论
93 0