atcoder beginer contest 295 D,G题解

本文介绍了如何使用C++解决atcoder Beginner Contest 295的D题(Three Days Ago)和G题(Minimum Reachable City)。D题关键在于判断字符串子段中字符出现次数是否均为偶数,利用二进制位表示状态进行求解。G题则涉及有向图的最小可达顶点问题,采用并查集的数据结构来解答。
摘要由CSDN通过智能技术生成

three days ago

D - Three Days Ago

题目大意:当一个由数字组成的字符串可以重新排列成(或已经是)某个字符串的重复两次时,它被认为是快乐的。您将获得一个由数字组成的字符串。查找满足以下所有条件的整数对数。

我们发现只要在某一个子段中,每种字符出现的次数都为偶数时,这个子段便是满足条件的。

那么,问题来了,怎么判断某一子段中各个字符出现的次数是不是偶数呢?

这里我们可以这样处理:我们对每一个字符出现的次数,它要么是奇数,要么是偶数,那么我们可以用一个二进制位表示该字符的状态,0表示出现次数为偶数,1表示出现次数为奇数,10位即可表示所有字符出现次数。这样一来,我们只需要10个二进制位就可以表示0-9各个数字的状态,开一个1<<10大小的数组就可以记录所有状态了。每一个状态转变只需要上一个状态state^(1<<(s[i]-'0'))即可。

例如20230322,我们记录一下前i个数所代表的状态:

i=0 0000000000

i=1 0000000100

i=2 0000000101

i=3 0000000001

i=4 0000001001

i=5 0000001000

i=6 0000000000

i=7 0000000100

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值