Educational Codeforces Round 189 (Rated for Div. 2)

A. A Number Between Two Others

考点:数学

思路:

因为题目要求。这个条件可以转换为(因为y能被x整除,相当于y是x的k倍)。同理也可以转换为

题目又说,于是我们可以继续转换一下

又因为

当k==2的时候,这样的m根本就不可能存在。于是k的取值就只能是

所以最后结论就是:

复杂度:O(1)

python 复制代码
import sys
input=sys.stdin.readline
t=int(input())
for _ in range(t):
    x,y=map(int,input().split())
    if y//x>2:
        print("YES")
    else:
        print("NO")

B. Alternating String

考点:贪心

思路:

题目要我们判断这个字符串能不能通过操作使其成为交替字符串,那我们可以把题目简化为找,相邻两个字符相同的个数,如果相邻的两个字符个数大于2串,就肯定是不行的。因为他直接替换字符的操作最多只能使用一次。

复杂度:O(n)

python 复制代码
import sys
input=sys.stdin.readline
t=int(input())
for _ in range(t):
    s=input().strip()
    n=len(s)
    i=1
    cnt=0
    for i in range(n-1):
        if s[i]==s[i+1]:
            cnt+=1
    if cnt>2:
        print("NO")
    else:
        print("YES")

C. Red-Black Pairs

考点:线性dp

思路:

因为他是一个2*n的表格,所以只可能有两种染色方法,第一种就是用一列的,第二种就是用两行的,因为你用了一行默认就是要用两行,因为行数是2。

于是我们就可以分两种情况来讨论:

当是一竖列的时候:

我们只需要计算把第i列变成同色的代价

当是两个横列的时候:

我们计算构成的2*2的区域中,第一排变成相同颜色的代价和加上第二排变成同色的代价。

所以最终状态转移方程

复杂度:O(n)

python 复制代码
import sys
input=sys.stdin.readline
t=int(input())
for _ in range(t):
    n=int(input())
    a=input().strip()
    b=input().strip()
    #dp[i]表示前i列完成合法分割与涂色的最小修改次数
    dp=[0]*(n+1)
    for i in range(1,n+1):
        c=i-1
        #选择1,当前列自己做为一个竖向对,两个格子如果颜色不同,代价为1,相同则代价为0
        cost_v=1 if a[c]!=b[c] else 0
        dp[i]=dp[i-1]+cost_v
        #选择2:当前列和前一列合并,变成两个横向对
        if i>=2:
            top=1 if a[c]!=a[c-1] else 0
            bot=1 if b[c]!=b[c-1] else 0
            zh=top+bot
            dp[i]=min(dp[i],dp[i-2]+zh)
    print(dp[n])

D. Exceptional Segments

考点:前缀和,状态压缩,数学

思路:

一开始我是用O(n)的写法写的,但是发现超时了。于是就把数字往后列了几个,发现这个前缀和其实是有规律的,他会是四个四个的一组,然后每次当除以4的余数为0和3的时候才是0,他为了让左右两部分相等,那么也就是其实只用找余数为0和余数为3的点就行了。

复杂度:O(1)

python 复制代码
import sys
input=sys.stdin.readline
mod=998244353
def count_0(m):
    if m<0:
        return 0
    return 1+(m+1)//4
def count_1(m):
    if m<0:
        return 0
    return (m+3)//4
t=int(input())
for _ in range(t):
    n,x=map(int,input().split())
    l0=count_0(x-1)
    l1=count_1(x-1)
    r0=count_0(n)-count_0(x-1)
    r1=count_1(n)-count_1(x-1)
    ans=(l0*r0+l1*r1)%mod
    print(ans)
相关推荐
2401_872418782 小时前
算法入门:数据结构-堆
数据结构·算法
weelinking2 小时前
【产品】12_接入数据库——让数据永久保存
jvm·数据库·python·react.js·数据挖掘·前端框架·产品经理
程序大视界3 小时前
【Python系列课程】Python正则表达式(下):环视、命名分组与日志实战
开发语言·python·正则表达式
xwz小王子3 小时前
手术机器人登上Science Robotics:2毫米纤细手臂,从3厘米切口完成腰椎神经减压
算法·机器人
TickDB3 小时前
美股行情 API 接入避坑:REST 快照、WebSocket 推送、盘前盘后数据的边界
人工智能·python·websocket·行情数据 api
枫叶v.4 小时前
Agent 分层存储架构设计:从记忆方法到中间件选型
开发语言·python
水兵没月4 小时前
逆向实战小记——某ToB商城网站分析学习
python·网络爬虫
黎阳之光4 小时前
视频孪生智护供水生命线:黎阳之光赋能医疗与园区水务高质量升级
运维·物联网·算法·安全·数字孪生
程序员小远4 小时前
Python自动化测试框架及工具详解
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
Black蜡笔小新5 小时前
自动化AI算法训练服务器DLTM制造业AI质检工作站助力制造业实现AI智检
人工智能·算法·自动化