C. Maximum Median

time limit per test

2 seconds

memory limit per test

256 megabytes

You are given an array a of n integers, where n is odd. You can make the following operation with it:

  • Choose one of the elements of the array (for example ai) and increase it by 1 (that is, replace it with ai+1).

You want to make the median of the array the largest possible using at most k operations.

The median of the odd-sized array is the middle element after the array is sorted in non-decreasing order. For example, the median of the array [1,5,2,3,5] is 3.

Input

The first line contains two integers n and k (1≤n≤2⋅105, n is odd, 1≤k≤109) --- the number of elements in the array and the largest number of operations you can make.

The second line contains n integers a1,a2,...,an (1≤ai≤109).

Output

Print a single integer --- the maximum possible median after the operations.

Examples

Input

Copy

复制代码
3 2
1 3 5

Output

Copy

复制代码
5

Input

Copy

复制代码
5 5
1 2 1 1 1

Output

Copy

复制代码
3

Input

Copy

复制代码
7 7
4 1 2 4 3 4 4

Output

Copy

复制代码
5

Note

In the first example, you can increase the second element twice. Than array will be [1,5,5] and it's median is 5.

In the second example, it is optimal to increase the second number and than increase third and fifth. This way the answer is 3.

In the third example, you can make four operations: increase first, fourth, sixth, seventh element. This way the array will be [5,1,2,5,3,5,5] and the median will be 5.

解题说明:此题是一道数学题,首先对数列进行从小到大排序,为了让中位数变大,让中位数变成和后面的数一样大,于是让该中位数在加完k后和后面的X个数字相同即可。

cpp 复制代码
#include<iostream>
#include<algorithm>
using namespace std;
int n, k, m, i;
int main()
{
	cin >> n >> k;
	int a[200004];
	m = n / 2;
	for (i = 0; i < n; i++)
	{
		cin >> a[i];
	}
	sort(a, a + n);
	for (i = a[m]; k > 0; i++) 
	{
		while (i == a[m + 1])
		{
			m++;
		}
		k = k - (m - n / 2 + 1);
	}
	if (k == 0)
	{
		cout << i<<endl;
	}
	else
	{
		cout << i - 1<<endl;
	}
	return 0;
}
相关推荐
liliangcsdn18 小时前
LLM如何辅助RAG从大量文档中筛选目标文档
开发语言·人工智能
无忧.芙桃18 小时前
C++IO库的超详细讲解
开发语言·c++
朗迹 - 张伟18 小时前
用AI开发QT——Qt与Trae开发环境搭建
开发语言·qt·策略模式
艺术电影节18 小时前
祝贺电影《撤离》《悼念词》《水草长生》 荣获亚洲艺术电影节提名
算法·推荐算法·电视
雨辰AI18 小时前
从 MySQL 迁移至人大金仓 V9 完整改造指南|分页 / 函数 / 语法兼容全部解决
java·开发语言·数据库·后端·mysql·政务
MATLAB代码顾问19 小时前
改进鲸鱼优化算法(IWOA)求解柔性作业车间调度问题(FJSP)——附MATLAB代码
开发语言·算法·matlab
量子-Alex19 小时前
【大模型】EvoLM论文LLM训练各个阶段效果
人工智能·算法·机器学习
阿里嘎多学长19 小时前
2026-05-03 GitHub 热点项目精选
开发语言·程序员·github·代码托管
yqcoder19 小时前
JavaScript 数据类型全景图:从基础到进阶
开发语言·javascript·ecmascript
Hello world.Joey19 小时前
OSTrack
人工智能·算法·目标检测·目标跟踪