题解:ABC277D - Takahashi‘s Solitaire

题解:ABC 277 D - Takahashi's Solitaire

·题目

链接:Atcoder

链接:洛谷

·难度

算法难度:入门。

思维难度:提高。

调码难度:入门。

综合评价:简单。

·算法

贪心+前缀和+动态规划

·思路

将卡牌按照除以m的余数从大到小进行排序,利用动态规划求出fi,即选取i为倒数第一个牌,前面(包括自己)最多可以取几个,当然,由于是按照除以m的余数从大到小进行排序的,在选取纸牌的过程中按照排序后的a顺序依次选取(n号纸牌的下一个是1号纸牌)直到下一个纸牌不符合要求为止,在选取的过程中f自然就求出来了,至于从哪个开始遍历取牌,随便找一个和上一张纸牌不符合要求的即可。

具体过程:先排序,从左往右找到第一个和上一张牌不符合要求的,从这张牌开始遍历(遍历顺序:该纸牌,该纸牌+1,该纸牌+2,......,n,1,2,3,......,该纸牌-1),记这张牌为id,若目前还没有遇到不合法的情况,fid=1,fid+1=2,fid+2=3......若遇到一张纸牌不合法,那么就更新id为当前纸牌,与前面操作相同(但是实际上只需要把这个f设成1,后面的依次+1就行了,而不需要实际更改变量id的值)。最后,通过前缀和求出每个i(1<=i<=n)的fi所对应选取情况的纸牌上写的数的总和,并打擂台求出每个总和的最大值,用所有纸牌上的数的和减去最大值就是答案。

·代价

O(n)。无论是什么都只会遍历一层。

·细节

对于求和操作中,如果用到n后面接了1,求和时需要特殊求(sum函数)。

·代码

cpp 复制代码
#include<bits/stdc++.h>
#define N 220000
using namespace std;
long long s[N]={},ans=0;
int a[N]={},f[N]={},m=0,n=0;
long long sum(int l,int r);
bool cmp(int x,int y);
int main(){
	scanf("%d%d",&n,&m);
	for(int i=1;i<=n;i++){
		scanf("%d",&a[i]);
	}
	sort(a+1,a+1+n,cmp);
	for(int i=1;i<=n;i++){
		s[i]=s[i-1]+a[i];
	}
	int id=-1;
	for(int i=1;i<=n&&id==-1;i++){
		int ot=i-1;
		if(ot==0){
			ot=n;
		}
		int mod1=a[i]%m,mod2=a[ot]%m;
		if((mod2+m-mod1)%m>1){
			id=i;
			break;
		}
	}
	if(id==-1){
		printf("0\n");
		return 0;
	}
	int lst=-1,now=1;
	for(int i1=id,i2=1;i2<=n;i1=(i1==n?1:i1+1),i2++){
		if(lst==-1){
			f[i1]=1;
		}else{
			int x=a[lst]%m,y=a[i1]%m;
			if((x+m-y)%m>1){
				now=1;
			}
			f[i1]=now;
		}
		lst=i1;
		now++;
	}
	for(int i=1;i<=n;i++){
		int c=f[i]-1,t=i,z=0;
		if(t-c<=0){
			c-=t;
			t=n;
		}
		z=t-c;
		ans=max(ans,sum(z,i));
	}
	printf("%lld\n",sum(1,n)-ans);
	return 0;
}
long long sum(int l,int r){
	if(l<=r){
		return s[r]-s[l-1];
	}
	return sum(l,n)+sum(1,r);
}
bool cmp(int x,int y){
	return x%m>y%m;
}

·注意

开longlong。

相关推荐
手写码匠5 小时前
手写 LLM 安全护栏:从内容审核到越狱防御的完整实现
人工智能·深度学习·算法·aigc
luj_17685 小时前
草酸与烟酸对消化及糖代谢的影响解析
服务器·c语言·开发语言·经验分享·算法
青风976 小时前
16-ADAPTRACK:基于自适应阈值的多目标跟踪匹配算法
人工智能·算法·目标跟踪
汤姆yu6 小时前
macOS系统下Aider完整安装、配置与实战使用教程
大数据·人工智能·算法·macos·github·copilot
Sam09276 小时前
【AI 算法精讲 14】TF-IDF:词频与逆文档频率
人工智能·python·算法·ai
AI科技星6 小时前
拓扑生命系统确定性理论:基于32维流形的遗传密码起源与衰老动力学( 中英双语顶刊终稿·标准数学符号)
开发语言·网络·人工智能·算法·机器学习·乖乖数学·全域数学
编程圈子7 小时前
电机驱动开发学习18. SVPWM空间矢量调制算法详解与实现
驱动开发·学习·算法
大鱼>7 小时前
机器学习基础:从零理解核心概念与算法分类
算法·机器学习·分类
AI科技星7 小时前
基于32维Cayley_Dickson超复数的全域拓扑统一场论——反重力、真空自持供能、维度瞬移与星际宇宙脑秩序体系
人工智能·学习·算法·机器学习·数据挖掘
aichitang20247 小时前
数论变换(NTT)
c++·算法·fft·ntt