[2.7]【CF933A】A Twisty Movement【CF926B】Add Points【CF917A】The Monster【CF919E】Congruence Equation

文章目录

  • T1:A Twisty Movement
    • 题目
    • 题解
    • code
  • T2:Add Points
    • 题目
    • 题解
    • code
  • T3:The Monster
    • 题目
    • 题解
    • code
  • T4:Congruence Equation
    • 题目
    • 题解
    • code

在这里插入图片描述

T1:A Twisty Movement

题目

题目

题解

因为aia_iai=1/21/21/2,于是我们可以确定答案一定是:[1,1,1,…][2,2,2…][1,1,1…][2,2,2…][1,1,1,…][2,2,2…][1,1,1…][2,2,2…][1,1,1,][2,2,2][1,1,1][2,2,2]这样的四段子序列(每一段都允许为空)中第二、三段所在区间翻转得到

我们可以从左往右做前缀和pre[i]pre[i]pre[i]表示[1,i][1,i][1,i]出现111的个数,后缀和suf[i]suf[i]suf[i]表示[i,n][i,n][i,n]出现222的个数


然后我们枚举二、三段的分界点k,k∈[1,n+1]k,k∈[1,n+1]k,k[1,n+1],再设一、二段的分界点为p,p∈[1,k]p,p∈[1,k]p,p[1,k],三、四段的分界点为q,q∈[k,n+1]q,q∈[k,n+1]q,q[k,n+1]

那么答案为(pre[p−1])+(suf[p]−suf[k])+(pre[q−1]−pre[k])+(suf[q])(pre[p-1])+(suf[p]-suf[k])+(pre[q-1]-pre[k])+(suf[q])(pre[p1])+(suf[p]suf[k])+(pre[q1]pre[k])+(suf[q])
在这里插入图片描述
将式子中括号括起来的当为一个整体
这个式子可以化为:
(pre[p−1]+suf[p]+pre[q−1]+suf[q])−(suf[k]+pre[k])(pre[p-1]+suf[p]+pre[q-1]+suf[q])-(suf[k]+pre[k])(pre[p1]+suf[p]+pre[q1]+suf[q])(suf[k]+pre[k])
p∈[1,k],q∈[k,n+1]p∈[1,k],q∈[k,n+1]p[1,k],q[k,n+1]

发现对于一个确定的kkk,我们要最大化前面括号的式子
而第一个括号里面的东西可以用线段树维护下pre[i−1]+suf[i]pre[i-1]+suf[i]pre[i1]+suf[i]
那么只用枚举kkk,再两次区间最大值查询,更新答案就好了

code

#include <cstdio>
#include <iostream>
using namespace std;
#define MAXN 2005
int n, result;
int a[MAXN], pre[MAXN], suf[MAXN], tree[MAXN << 2];void insert ( int t, int l, int r, int id, int val ) {if ( l == r ) {tree[t] = val;return;}int mid = ( l + r ) >> 1;if ( id <= mid )insert ( t << 1, l, mid, id, val );elseinsert ( t << 1 | 1, mid + 1, r, id, val );tree[t] = max ( tree[t << 1], tree[t << 1 | 1] );
}int query ( int t, int l, int r, int L, int R ) {if ( L <= l && r <= R )return tree[t];int mid = ( l + r ) >> 1;int ans = 0;if ( L <= mid )ans = max ( ans, query ( t << 1, l, mid, L, R ) );if ( mid < R )ans = max ( ans, query ( t << 1 | 1, mid + 1, r, L, R ) );return ans;
}int main() {scanf ( "%d", &n );for ( int i = 1;i <= n;i ++ )scanf ( "%d", &a[i] );for ( int i = 1;i <= n;i ++ )pre[i] = pre[i - 1] + ( a[i] == 1 );for ( int i = n;i >= 1;i -- )suf[i] = suf[i + 1] + ( a[i] == 2 );for ( int i = 1;i <= n + 1;i ++ )insert ( 1, 1, n + 1, i, pre[i - 1] + suf[i] );for ( int i = 1;i <= n + 1;i ++ ) {int tmp1 = query ( 1, 1, n + 1, 1, i ), tmp2 = query ( 1, 1, n + 1, i, n + 1 );result = max ( result, tmp1 + tmp2 - pre[i - 1] - suf[i] ); }printf ( "%d", result );return 0;
}

T2:Add Points

题目

题目

题解

这道题实在不知道怎么讲,我觉得直接扔一句话就懂了
排完序后两两距离的最大公约数

code

#include <cstdio>
#include <algorithm>
using namespace std;
#define MAXN 100005
int n;
int x[MAXN];int gcd ( int x, int y ) {if ( ! y )return x;elsereturn gcd ( y, x % y );
}int main() {scanf ( "%d", &n );for ( int i = 1;i <= n;i ++ )scanf ( "%d", &x[i] );sort ( x + 1, x + n + 1 );int d = x[2] - x[1];for ( int i = 2;i < n;i ++ ) {int dis = x[i + 1] - x[i];d = gcd ( d, dis );}int result = 0;for ( int i = 1;i < n;i ++ )result += ( x[i + 1] - x[i] ) / d - 1;printf ( "%d", result );return 0;
}

T3:The Monster

题目

题目

题解

其实还是有点意思,我认为比T2T2T2要难一点
首先直接纯暴力250002^{5000}25000可以直接当场去世了


考虑枚举起点,用tottottot记录,(((+1+1+1)))−1-11
tot==0tot == 0tot==0,说明匹配成功result++result++result++


对于???就麻烦一点了
tot>0tot>0tot>0,表示需要右括号匹配,使???为右括号,
因为右括号一定可以改为左括号(期待后面能够匹配成功),
因此change++change++change++changechangechange为可以修改为左括号的???个数)

tot<0tot<0tot<0???只能为左括号,并且不能计入num
在这里插入图片描述


如果某一个时刻,tot<0,num>0tot<0,num>0tot<0,num>0,说明可以将之前的右括号改为左括号,则tot+=2,num−−tot += 2,num--tot+=2,num

剪枝部分:若tot<0,num=0tot<0,num=0tot<0,num=0,说明此序列当前及以后都不会合法,直接breakbreakbreak

code

#include <cstdio>
#include <cstring>
#define MAXN 5005
char s[MAXN];
int result, tot, change;int main() {scanf ( "%s", s );int len = strlen ( s );for ( int i = 0;i < len;i ++ ) {tot = 0, change = 0;for ( int j = i;j < len;j ++ ) {if ( s[j] == '(' )tot ++;else if ( s[j] == ')' ) tot --;else {if ( tot > 0 )tot --, change ++;elsetot ++;}if ( tot < 0 && change > 0 )tot += 2, change --;//°Ñ֮ǰµ±³É')'ÌṩµÄ-1¼Ó»ØÀ´ÔÙ¼ÓÉÏ'('µÄ¹±Ï× if ( tot < 0 && ! change )break;if ( ! tot )result ++;}}printf ( "%d", result ); return 0;
}

T4:Congruence Equation

题目

题目

题解

对于这种数论题只想说一句:不康题解:这神马玩意儿;康完题解:太水了
在这里插入图片描述


n∗an≡b(modp)n*a^n≡b(mod\ p)nanb(mod p),加上费马那一堆人的鬼定理
我们知道第一个乘数nnn的循环节是ppp
而指数nnn的循环节是φ(p)φ(p)φ(p),又因为ppp为质数,所以φ(p)=p−1φ(p)=p-1φ(p)=p1
综上n⋅ann⋅a^nnan有循环节p∗(p−1)p*(p−1)p(p1)


然后就可以设n=j∗(p−1)+in=j*(p-1)+in=j(p1)+i,接着开始搞事
n∗an≡b(modp)n*a^n≡b(mod\ p)nanb(mod p)
(j∗(p−1)+i)∗aj∗(p−1)+i≡b(modp)(j*(p-1)+i)*a^{j*(p-1)+i}≡b(mod\ p)(j(p1)+i)aj(p1)+ib(mod p)
(j∗p−j+i)∗ai≡b(modp)(j*p-j+i)*a^i≡b(mod\ p)(jpj+i)aib(mod p)
(i−j)∗ai≡b(modp)(i-j)*a^i≡b(mod\ p)(ij)aib(mod p)
j≡i−bai(modp)j≡i-\frac{b}{a^i}(mod\ p)jiaib(mod p)
然后就可以枚举iii解出j,nj,nj,n搞到一个最小解,根据循环节算有几个
x−minnp⋅(p−1)\frac{x−minn}{p⋅(p−1)}p(p1)xminn

code

#include <cstdio>
#define int long long
int a, b, p, x, result;int qkpow ( int x, int y ) {int ans = 1;while ( y ) {if ( y & 1 )ans = ans * x % p;x = x * x % p;y >>= 1;}return ans;
}signed main() {scanf ( "%lld %lld %lld %lld", &a, &b, &p, &x );for ( int i = 1;i < p;i ++ ) {int j = ( i - b * qkpow ( qkpow ( a, i ), p - 2 ) % p + p ) % p;int minx = j * ( p - 1 ) + i;if ( minx <= x )result += ( x - minx ) / ( p * ( p - 1 ) ) + 1;}printf ( "%lld", result );return 0;
} 

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/317965.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LIS最长上升子序列

LIS算是比较经典的问题&#xff0c;常用的是O(n^2)的方法 for(int i1;i<n;i){dp[i]1;for(int j1;j<i;j){if(a[j]<a[i])dp[i]max(dp[i],dp[j]1);}mxmax(mx,dp[i]);}我们这里优化成O(nlogn) 我们模拟一个栈stack&#xff0c;每读入一个数&#xff0c;如果这个数大于栈顶…

EF Core 数据库 Provider 一览

当 EF Core 1.x 系列和 2.0 版本之间经过重大的重写时&#xff0c;所有 EF Core 数据库 Provider 都受到重创。从那时起&#xff0c;各种私人和商业开发团队一直在努力填补这个空白。正文当 EF Core 1.x 系列和 2.0 版本之间经过重大的重写时&#xff0c;所有 EF Core 数据库 P…

[3.3训练赛]One-Dimensional(矩阵快速幂),Freda的迷宫(无向图强连通分量+并查集),一道防AK好题

文章目录T1:One-DimensionaltitlesolutioncodeT2:【NOIP模拟赛】Freda的迷宫titlesolutioncodeT3:【NOIP模拟赛】一道防AK好题titlesolutioncode确实没想到自己写文章能隔这么久&#xff0c;鸽王预警 T1:One-Dimensional title 考虑一个含有 N 个细胞的一维细胞自动机。细胞…

牛客网专题 概率dp

文章目录概念&#xff1a;例题引入&#xff1a;解答&#xff1a;Happy Running NC15532题意&#xff1a;题解&#xff1a;代码&#xff1a;poj2096 NC106693 Collecting Bugs题意&#xff1a;题解&#xff1a;代码&#xff1a;NC210477 带富翁题意&#xff1a;题解&#xff1a;…

.NET Core 3.0 特性初探:C# 8、WPF、Windows Forms、EF Core

.NET Core 的下一个主要版本最近进入了预览阶段&#xff0c;.NET Core 3.0 将支持使用 Windows Presentation Foundation &#xff08;WPF&#xff09;、Windows Forms&#xff08;WinForms&#xff09;、Entity Framework &#xff08;EF&#xff09;、Blazor、 C# 8 和.NET S…

YBTOJ洛谷P4074:糖果公园(树上莫队)

文章目录解析update:代码所谓树上莫队&#xff0c;就是在树上的莫队 &#xff08;逃&#xff09; 传送门 解析 似乎就是树上的这道题 考虑如何转化为序列问题呢? 考虑dfs序 但是又一个问题。。。 似乎这条链的dfs序不连续啊 树剖一下就好啦 考虑更阳间的方法 求出这棵树的欧…

【用梨泰院class中的财阀世家带你洞悉替罪羊树】Scapegoat Tree原理,模板,例题

我想写在前面&#xff0c;本文财阀世家全是虚构&#xff0c;没有诋毁之意&#xff0c;如有雷同&#xff0c;纯属巧合 红色预警&#xff01;&#xff01;&#xff01;红色预警 文章目录Scapegoat Tree概念模板变量声明Bad函数判断是否需要重构理解模板rebuild重构理解模板inser…

领域驱动设计,让程序员心中有码(五)

1 从搬砖谈领域对象有一个古老的故事&#xff0c;大概是这样的。作者问三个建筑工地上的工人他们在干什么&#xff1f;有一个没精打采的说&#xff0c;我在挖洞&#xff01;而另一一个人却说&#xff0c;我在盖一座房子。还有一个人说&#xff0c;我在建立一座巨大的城市。…

.NET Core实战项目之CMS 第十四章 开发篇-防止跨站请求伪造(XSRF/CSRF)攻击处理...

通过 ASP.NET Core&#xff0c;开发者可轻松配置和管理其应用的安全性。 ASP.NET Core 中包含管理身份验证、授权、数据保护、SSL 强制、应用机密、请求防伪保护及 CORS 管理等等安全方面的处理。 通过这些安全功能&#xff0c;可以生成安全可靠的 ASP.NET Core 应用。而我们这…

模板:左偏树

文章目录解析可以解决的问题定义&#xff1a;左偏树的基本性质基本结论操作合并访问与删除堆顶元素插入元素批量插入删除已知元素所谓左偏树&#xff0c;就是往左偏的树 下面介绍一下它的一个兄弟&#xff1a; 《右偏树》 &#xff08;逃&#xff09; 解析 所谓左偏树&#…

迎开学水题狂欢赛(舞踏会[dp+三叉树],HH去散步[矩阵快速幂],排序[模拟],铁路旅行[线段树])

快速简单记录老师口胡&#xff08;可能就我自己看得懂了吧…&#xff09; 文章目录T1&#xff1a;舞踏会titlesolutioncodeT2&#xff1a;HH去散步titlesolutioncodeT3&#xff1a;排序titlesolutioncodeT4&#xff1a;铁路旅行titlesolutioncodeT1&#xff1a;舞踏会 title …

CSP2021提高组复赛解析

前言 终于出成绩了我可以写博客辣&#xff0c;官方数据还没出就先放洛谷的题目链接了。 正题 T1-廊桥分配 https://www.luogu.com.cn/problem/P7913 题目大意 有m1m_1m1​种一类飞机&#xff0c;m2m_2m2​种二类飞机&#xff0c;每个飞机有一个占用时间的区间。要给两类飞机…

一起开心集训队第一周训练赛2021/3/14

文章目录比赛链接A CodeForces 1481D AB Graph题意&#xff1a;题解&#xff1a;代码&#xff1a;B CodeForces 1481E Sorting Books题意&#xff1a;题解&#xff1a;代码&#xff1a;C CodeForces 1478D Nezzar and Board题意&#xff1a;题解&#xff1a;代码&#xff1a;D …

使用Azure DevOps持续集成GitHub项目

点击蓝字关注我微软的Azure DevOps是一款软件开发管理工具&#xff0c;整合了需求、代码、编译、测试、发布等所有功能于一身。今天我们就来看看如何用Azure DevOps对自己GitHub上的项目做持续集成&#xff0c;并能在GitHub显示最新编译状态。其实在不久之前&#xff0c;Azure …

[BZOJ 3811]玛里苟斯(线性基)尽量理解的题解

文章目录titlesolutioncodetitle 魔法之龙玛里苟斯最近在为加基森拍卖师的削弱而感到伤心&#xff0c;于是他想了一道数学题。 S 是一个可重集合&#xff0c;S{a1,a2,…,an}。 等概率随机取 S 的一个子集 A{ai1,…,aim}。 计算出 A 中所有元素异或和&#xff0c;记为 x, 求 x^…

CF464E The Classic Problem(线段树 最短路)

CF464E The Classic Problem \(\bigstar\texttt{Hint}\)&#xff1a;发现没有什么好的突破口&#xff1f;为什么不想想怎样才能实现题目中 \(2^x\) 的加减法呢&#xff1f; 可见每次加减法&#xff0c;我们要做的是将添加的 \(1\) 和右边的连续的 \(1\) 合并为一整段&#xff0…

C. Longest Simple Cycle

C. Longest Simple Cycle 题意&#xff1a; 有n条链&#xff0c;第i条链上有c[i]个点&#xff0c;a[i]为第i条链的顶点与第i-1条链的连接点&#xff0c;b[i]为第i条链的最后一个点与第i-1条链的连接点。通过上面的方法连接链会产生很多的环&#xff0c;问这些环的最大长度。 …

【CF813F】Bipartite Checking(线段树分治+可删除并查集)

文章目录titlesolutioncodetitle You are given an undirected graph consisting of n vertices. Initially there are no edges in the graph. Also you are given q queries, each query either adds one undirected edge to the graph or removes it. After each query you…

在.Net Core WebAPI下给Swagger增加导出离线文档功能

一丶前言最近刚接触到Swagger&#xff0c;在github上下载了它的源码和demo学习了一遍&#xff0c;发现这个组件非常好用&#xff0c;不过不足的是它没有导出离线文档的功能&#xff0c;于是乎我就想给它加一个导出功能Swagger Github开源地址二丶思路其实说白了api文档就是一个…

YBTOJ洛谷P4331:数字序列(左偏树)

文章目录题目描述数据范围解析代码题目描述 数据范围 n<1e6n<1e6n<1e6 解析 先考虑简单情况 如果原数列是单调递增的&#xff0c;显然应该使biaib_ia_ibi​ai​ 如果单调递减&#xff0c;应该取中位数 那么原数列如果分成单调递减的几段&#xff0c;那么每一段都取中…