小埋的解密游戏的题解

目录

原题描述:

题目描述

输入格式

输出格式

样例 #1

样例输入 #1

样例输出 #1

样例 #2

样例输入 #2

样例输出 #2

提示

主要思路:

代码实现code:


原题描述:

题目描述

小埋最近在玩一个解密游戏,这个游戏的解密方法是这样的,这个游戏会给你提供 n 个数,让我们求出这 n 个数里面,有多少个连续的数的平均数大于某个给定的数 M 。这个数可能会很大,所以我们要输出这个数对 1e9+7的取模结果。现在小埋对于这个游戏的解法还是不太理解,现在请你帮助小埋解决这个问题。

输入格式

输入有两行。第一行为两个数 n和 M 。第二行为n 个数。

输出格式

输出的数占一行,即问题的解对 1e9+7 取模的结果。

样例 #1

样例输入 #1

4 3 
1 5 4 2

样例输出 #1

5

样例 #2

样例输入 #2

4 4 5 2 7 3

样例输出 #2

6

提示

1 \le n \le 2 * 10^5

1 \le M \le 3*10^3

所有的数均为正整数且不大于5000

主要思路:

这个题目。由于是平均数>m,所以我们可以将所有的数-m,求一遍前缀和,进行归并排序,求出所有的正序对(i<j,且a[i]<a[j])的数对。

代码实现code:

#include<bits/stdc++.h>
using namespace std;
const int mod=1e9+7;
int a[200010],b[200010];
long long ret=0;
int shu[200010];
void merge(int l,int r)
{
	if(l == r)
	{
		return;
	}
	int mid=(l+r)/2;
	merge(l,mid);
	merge(mid+1,r);//归并排序分治
	int i=l,j=mid+1,tot=l;
	while(i<=mid&&j<=r)
	{
		if(a[i]<a[j])
		{
			ret+=(mid-i+1)%mod;
			ret%=mod;
			b[tot++]=a[j++];	
		}
		else
		{
			b[tot++]=a[i++];
		}
	}
	while(i<=mid)
	{
		b[tot++]=a[i++];	
	}
	while(j<=r)
	{
		b[tot++]=a[j++];
	}//区间合并
	for(int i=l;i<=r;i++)
	{
		a[i]=b[i];
	}
}
int main()
{
	int n,m;
	cin>>n>>m;
	for(int i=1;i<=n;i++)
	{
		cin>>shu[i];
		shu[i]-=m;
		a[i] = a[i-1]+shu[i];
	}
	merge(0,n);
	cout<<ret;
	return 0;
}

相关推荐

  1. 微信程序中实现方法

    2024-02-05 14:52:04       41 阅读
  2. 基于uni-app点sdk设计

    2024-02-05 14:52:04       30 阅读
  3. APP接入游戏崭新趋势

    2024-02-05 14:52:04       51 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-05 14:52:04       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-05 14:52:04       106 阅读
  3. 在Django里面运行非项目文件

    2024-02-05 14:52:04       87 阅读
  4. Python语言-面向对象

    2024-02-05 14:52:04       96 阅读

热门阅读

  1. QT 的 blockSignals(true) 的作用范围

    2024-02-05 14:52:04       46 阅读
  2. C++:通过count和find判断vector中是否包含某个数据

    2024-02-05 14:52:04       45 阅读
  3. 正则表达式

    2024-02-05 14:52:04       42 阅读
  4. WSL和Ubuntu编译IJKPlayer

    2024-02-05 14:52:04       44 阅读
  5. 前端实现数组的去重

    2024-02-05 14:52:04       54 阅读
  6. 排序刷题3

    2024-02-05 14:52:04       56 阅读
  7. 【Ubuntu】安装filebeat

    2024-02-05 14:52:04       55 阅读
  8. ubuntu 安装 ffmpeg 6.0

    2024-02-05 14:52:04       57 阅读
  9. 蓝桥杯典型真题分析详解--编程思维--日期统计

    2024-02-05 14:52:04       44 阅读
  10. ASR 概述

    2024-02-05 14:52:04       47 阅读