E. MEX and Increments---dp+优先队列+贪心

在这里插入图片描述
摘自:ThXe
原文链接:https://blog.csdn.net/thexue/article/details/122063160

首先计数把每个数字出现的次数记录,对于下标i,我们需要让0-i-1的数至少出现一次,然后让数字i全体加1,这里用动态规划的思想,假设dp[i]是使得数列出现0-i每个至少一个的最小步数 那么 ans[i+1]=dp[i]+cnt[i+1],此时满足0-i至少出现一次,且所有等于i+1的值都被加1,MEX就位i+1,对于dp的转移来说,dp[i+1]=dp[i]+(i+1- 数组中最接近i+1的一个数字),这里可以用优先队列处理,事实上我们会发现数一定是从小到大所以用栈也是可以处理的。具体的做法是,转移后,将i都推入优先队列或栈中,作为最接近i+1的一个备选答案,如果栈空说明个数不够,输出-1,随后所有数都不可能成立。更进一步的,发现dp只会用到上一个状态,那用一个变量记录即可。

#include <iostream>
#include <cstring>
#include <algorithm>
#include <queue>
using namespace std;
#define int long long 
const int N = 200010;
int a[N],cnt[N];
void solve()
{
	for(int i=0;i<N;i++)cnt[i]=0;
	int n,x;cin>>n;
	for(int i=0;i<n;i++)cin>>x,cnt[x]++;
	int s=0;
	priority_queue<int>q;
	for(int i=0;i<=n;i++)
	{
		cout<<max(-1ll,s+cnt[i])<<' ';
		while(cnt[i]--)q.push(i);
		if(q.size())
		{
			s+=i-q.top();
			q.pop();
		}
		else s=-1e18;
	}
	cout<<'\n';
} 
signed main()
{		
	int T;cin>>T;
	while(T--)solve();
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
"Error while obtaining sizes from MEX S-function" 是一个常见的错误消息通常在使用 MATLAB Simulink 中的 MEX S-function 时出现。这个错误消息表示在获取 MEX S-function 的大小时发生了错误。 MEX S-function 是一种用 C 或 C++ 编写的 Simulink S-function,它可以通过 MATLAB 的 MEX 接口与 Simulink 模型进行交互。当在模型中使用 MEX S-function 时,Simulink 需要获取该 S-function 的输入和输出端口的大小信息,以便正确地连接和运行模型。 出现 "Error while obtaining sizes from MEX S-function" 错误消息的原因可能有以下几种: 1. MEX S-function 的代码中存在错误:可能是由于代码中的语法错误、逻辑错误或其他编程错误导致的。需要检查 MEX S-function 的代码并修复错误。 2. MEX S-function 的输入和输出端口定义不正确:MEX S-function 的输入和输出端口定义应该与模型中的连接匹配。需要确保端口的数量、数据类型和维度等信息正确无误。 3. 编译或链接问题:在编译或链接 MEX S-function 时可能出现问题,导致无法正确获取大小信息。需要检查编译和链接过程中是否存在错误,并确保生成的 MEX 文件与模型匹配。 解决 "Error while obtaining sizes from MEX S-function" 错误的方法包括: 1. 检查 MEX S-function 的代码并修复错误。 2. 确保 MEX S-function 的输入和输出端口定义正确。 3. 检查编译和链接过程中是否存在错误,并确保生成的 MEX 文件与模型匹配。 4. 如果问题仍然存在,可以尝试重新编译 MEX S-function 或者重新生成模型。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_WAWA鱼_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值