社区讨论

玄关求条!!WA两个,T两个

P14915「QFOI R3」算法竞赛参与者 1已保存回复 0

讨论操作

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

当前回复
0 条
当前快照
1 份
快照标识符
@mjpk2k68
此快照首次捕获于
2025/12/28 17:57
2 个月前
此快照最后确认于
2025/12/28 22:08
2 个月前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
int n,k,d;
int f[100005];
int main(){
	scanf("%d%d%d",&n,&k,&d);
	for(int i=1;i<=n;i++){
		scanf("%d",&f[i]);
	}
	sort(f+1,f+n+1);
	int num=2;
	int cnt=0;
	int last=f[1];
	for(int i=2;i<=n;i++){
		if(num!=1){
			if(f[i]-last<=d) num++,last=f[i];
			else{
				while(num<=k&&f[i]-last>d){
					last+=d;
					cnt++;
					num++;
				}
				if(num>k) num=1;
				else num++;
			}
		}
		if(num==1) last=f[i],num=2;
		if(num>k&&i!=n){
			num=1;
		}
	}
	printf("%d",cnt+k-num+1);
	return 0;
}

回复

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

正在加载回复...