社区讨论

求调

AT_abc379_c [ABC379C] Sowing Stones参与者 4已保存回复 5

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
5 条
当前快照
1 份
快照标识符
@m3azven8
此快照首次捕获于
2024/11/10 10:47
去年
此快照最后确认于
2025/11/04 15:00
4 个月前
查看原帖
WA x3,应该是一些小细节出了问题
主要思路是定义指针 p,代表从右往左第一个没有石头的点,然后批量模拟有石头的地方该把石头给哪里,计算移动总次数。
CPP
#include<iostream>
#include<algorithm>
using namespace std;
#define int long long
struct node{
	int id,num;
}a[200005];
bool cmp(node x,node y){
	return x.id<y.id;
}

signed main(){
	int n,m;
	cin>>n>>m;
	for(int i=1;i<=m;i++) cin>>a[i].id;
	for(int i=1;i<=m;i++) cin>>a[i].num;
	sort(a+1,a+m+1,cmp);
	int p=n,cnt=m,ans=0;
	while(cnt>=1){
		if(p-a[cnt].id+1<a[cnt].num){
			cout<<-1;
			return 0;
		}
		p-=a[cnt].num;
		ans+=(p+1-a[cnt].id+p+a[cnt].num-a[cnt].id)*a[cnt].num/2;
		cnt--;
	}
	cout<<ans;
	return 0;
}

回复

5 条回复,欢迎继续交流。

正在加载回复...