Add, Divide and Floor(cf round 158 div2)

题目: 给你一个整数数组 a1,a2,...,an 。在一次操作中,你可以选择一个整数 x ,并用 (a[i]+x)/2 替换 ai ( (a[i]+x)/2表示将 y(a[i]+x)/2舍入为最接近的整数(下取整)。 ⌊y⌋ 表示将 y 舍入为最接近的整数)来替换从 1 到 n 的所有 i。请注意,每次操作都会影响数组中的所有元素。打印使数组中所有元素相等所需的最小操作数。如果操作次数小于或等于 n,则打印每次操作所选择的 x 。如果有多个答案,则打印任意一个。

输入样例

4

1

10

2

4 6

6

2 1 2 1 2 1

2

0 32

输出样例

复制代码
0
2
2 5
1
1
6 

思路:

将a1~an 进行排序

a1<=a2<=a3<=...<=an

若 b<=c 则 (b+x)/2<=(c+x>)/2;

类似与夹逼定理的思路 只需要让 a1(最小值)与an(最大值)相等 其余的值都就相等了

即a1=a2=a3=...=an

然后再去思考如何取值让最大值和最小值相等操作最小

x取1 3 5 7 ...2n+1 进行操作 会让最大值和最小值的差值都一样

x取0 2 4 6 .......2n 进行操作 会让最大值和最小值的差值都一样

那不妨就只取1、0(x的大小不会改变答案,x的奇偶性可以改变答案)

思考什么样的条件下 x取1 什么样的条件下x取0

当最小值为奇数时

若x取1 这样让(最小值+x)/2 可以+1 (最大值+1)/2可能+1 也可能+0

若x取0 (最小值+x)/2 +0 (最大值+1)/2可能+1 也可能+0

故取1

当最小值为偶数时

若x取1 (最小值+x)/2 +0 (最大值+1)/2可能+1 也可能+0

若x取0 (最小值+x)/2 +0 (最大值+1)/2 +0

故取0

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<cstring>
#include<vector>
#include<map>
#include<cmath>
using namespace std;
typedef long long ll;
const int N=2e5+10;
vector<ll>v;
map<ll,ll>mp;
ll a[N];
int main()
{
	int t;cin>>t;
	while(t--)
	{
		int n;cin>>n;
		for(int i=1;i<=n;i++) cin>>a[i];
		sort(a+1,a+1+n);
		ll min1=a[1],max1=a[n];
		v.clear();
		if(n==1) cout<<"0"<<endl;
		else
		{
	
		while(min1!=max1)
		{
			if(min1!=0)
			{
			if(min1%2!=0)
			{
				v.push_back(1);
				min1=(min1+1)/2;
				max1=(max1+1)/2;
			}
			else
			{
				v.push_back(0);
				min1/=2;
				max1/=2;
			}
		   }
		   else
		   {
		   	v.push_back(0);
		   	max1/=2;
		   }
		}
		cout<<v.size()<<endl;
		if(v.size()<=n)
		{
			for(int i=0;i<v.size();i++)
			{
				cout<<v[i]<<" ";
			}
			cout<<endl;
		}
	}
	}
	return 0;
}
相关推荐
alphaTao1 分钟前
LeetCode 每日一题 2026/4/20-2026/4/26
算法·leetcode·职场和发展
Robot_Nav42 分钟前
TD3 —— 双延迟深度确定性策略梯度算法文献解读
算法·td3·drl
斯维赤43 分钟前
每天学习一个小算法:归并排序
学习·算法·排序算法
王老师青少年编程1 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【区间贪心】:区间覆盖(加强版)
c++·算法·贪心·csp·信奥赛·区间贪心·区间覆盖(加强版)
碧海银沙音频科技研究院1 小时前
杰理项目开发大全课程
人工智能·深度学习·算法
风一样的航哥1 小时前
LeetCode 2615 等值距离和:前缀和优化O(n)解法深度解析
数据结构·算法·leetcode
生成论实验室2 小时前
生成态势猜想:一种统一的宇宙动力学语法
人工智能·科技·神经网络·算法·信息与通信
旖-旎2 小时前
深搜(二叉树的所有路径)(6)
c++·算法·leetcode·深度优先·递归
啦啦啦_99992 小时前
3. KNN算法之 常用的距离度量方式(欧式&曼哈顿&切比雪夫&闵式距离)
算法
朝风工作室2 小时前
实时全景拼接|支持任意路数输入,8*8K RTX3050 实测 10ms 内
图像处理·算法·计算机视觉