C - Make a Rectangle

从大到小贪心即可。

# include <bits/stdc++.h>
using namespace std;
map<int,int>m;
int main()
{
int n, a;
scanf("%d",&n);
while(n--) scanf("%d",&a), m[a]++;
int r=0, c=0;
for(auto i:m)
if(i.second>3) r=c=i.first;
else if(i.second>1) c=r,r=i.first;
printf("%lld\n",(long long)r*c);
}

D - Coloring Dominoes

就是个乘法原理。

# include <bits/stdc++.h>
using namespace std;
#define P 1000000007
int n;
char s1[100], s2[100];
int main(){
scanf("%d%s%s",&n,s1,s2);
long long ans=s1[0]==s2[0]?3:6;
for(int i=1; i<n; ++i){
if(s1[i-1]==s2[i-1]) ans=ans*2%P;
if(s1[i]!=s2[i]&&s1[i-1]!=s2[i-1]&&s1[i]!=s1[i-1]&&s2[i]!=s2[i-1]) ans=ans*3%P;
}
printf("%lld",ans);
}

E - Don't Be a Subsequence

首先考虑如何求答案串的最小长度。

显然是可以dp的。

首先考虑长度为1的答案,显然标记一下哪些字母没出现过即可。

否则令\(dp[i]\)表示\(suffix(i)\)的以\(s[i]\)为开头的答案串的最小长度,容易得到\(dp[i]=min(dp[j]+1)\),其中\(j>i\)并且\(s[j]\)是\(suffix(i)\)里所有同样字符的最左端。

对于每个\(i\),这样的j最多只有26个,可以通过一次\(O(26\times len)\)预处理出来。

如果求出了答案串的最小长度,如何确定答案串的最小字典序呢?

考虑dp转移的过程,每次用字典序靠前的字符来进行转移就行了。

记录一下路径,倒序输出即可。

时间复杂度\(O(26\times len)\)。

# include <bits/stdc++.h>
using namespace std;
const int N=200005;
int vis[26];
char s[N];
struct Node{int len, id, c;}dp[N], ans; int main ()
{
scanf("%s",s+1);
int len=strlen(s+1);
for (int i=len; i>=1; --i) {
dp[i].len=dp[vis[0]].len+1; dp[i].id=vis[0]; dp[i].c=0;
for (int j=1; j<=25; ++j) if (dp[i].len>dp[vis[j]].len+1) dp[i].len=dp[vis[j]].len+1, dp[i].id=vis[j], dp[i].c=j;
vis[s[i]-'a']=i;
}
for (int i=0; i<=25; ++i) if (!vis[i]) {printf("%c\n",i+'a'); return 0;}
ans.len=dp[vis[0]].len; ans.id=vis[0]; ans.c=0;
for (int i=1; i<=25; ++i) if (ans.len>dp[vis[i]].len) ans.len=dp[vis[i]].len, ans.id=vis[i], ans.c=i;
while (ans.id) putchar(ans.c+'a'), ans.c=dp[ans.id].c, ans.id=dp[ans.id].id;
putchar(ans.c+'a');
putchar('\n');
return 0;
}

F - Flip and Rectangles

我们首先考虑一个\(2\times 2\)的方格,如果包含奇数个黑格子的话,我们把它称为\(Bad-Part\)。

显然,对于每一个最后可能出现的黑矩形,其中必然不包含\(Bad-Part\)。

因为对于\(Bad-Part\),无论怎么操作都无法全部变黑。

假设\(S\)不包含任意\(Bad-Part\),那么我们可以进行一些操作使得S全部变黑。

如何证明?

考虑S的最上面一行和最左边一行,由于我们必然要把他们变成黑色,所以操作是一定的,而这些操作也一定可以将

整个S变黑。

现在的问题是,找到一个面积最大的\(S\),使得S不包含任何\(Bad-Part\)。

我们可以把每个\(Bad-Part\)缩到\(2\times 2\)方格中心的那个位置,我们把这样的点称为\(Bad-Point\)。

那么问题就变成了经典的最大全0子矩阵了。

而这个问题有经典的悬线法可以\(O(nm)\)解决。

# include <bits/stdc++.h>
using namespace std;
const int N=2005;
char s[N][N];
int n, m, a[N], b[N]; int main()
{
scanf("%d%d",&n,&m);
int ans=max(n,m);
for(int i=0;i<n;i++) scanf("%s",s[i]);
for(int i=0;i<n;i++) {
for(int j=0;j<m-1;j++) {
if(i&&!(s[i-1][j+1]^s[i][j]^s[i-1][j]^s[i][j+1])) a[j]++;
else a[j]=1;
}
int t=0;
for(int j=0;j<=m-1;j++) {
while(t&&a[b[t-1]]>=a[j]) {
int x=b[--t];
if(t==0) ans=max(ans,(j+1)*a[x]);
else ans=max(ans,(j-b[t-1])*a[x]);
}
b[t++]=j;
}
}
printf("%d\n",ans);
return 0;
}

AtCoder Regular Contest 081的更多相关文章

  1. AtCoder Regular Contest 081 F - Flip and Rectangles

    题目传送门:https://arc081.contest.atcoder.jp/tasks/arc081_d 题目大意: 给定一个\(n×m\)的棋盘,棋盘上有一些黑点和白点,每次你可以选择一行或一列 ...

  2. AtCoder Regular Contest 081 E - Don't Be a Subsequence(字符串DP)

    引用自:onion_cyc 字符串DP一直不是强项...以后没思路的题就想DP和网络流23333333 f[i]表示从i开始的后缀非子序列的最短长度  pos[i][j]表示从i开始的j字符最早出现位 ...

  3. AtCoder Regular Contest 061

    AtCoder Regular Contest 061 C.Many Formulas 题意 给长度不超过\(10\)且由\(0\)到\(9\)数字组成的串S. 可以在两数字间放\(+\)号. 求所有 ...

  4. AtCoder Regular Contest 094 (ARC094) CDE题解

    原文链接http://www.cnblogs.com/zhouzhendong/p/8735114.html $AtCoder\ Regular\ Contest\ 094(ARC094)\ CDE$ ...

  5. AtCoder Regular Contest 092

    AtCoder Regular Contest 092 C - 2D Plane 2N Points 题意: 二维平面上给了\(2N\)个点,其中\(N\)个是\(A\)类点,\(N\)个是\(B\) ...

  6. AtCoder Regular Contest 093

    AtCoder Regular Contest 093 C - Traveling Plan 题意: 给定n个点,求出删去i号点时,按顺序从起点到一号点走到n号点最后回到起点所走的路程是多少. \(n ...

  7. AtCoder Regular Contest 094

    AtCoder Regular Contest 094 C - Same Integers 题意: 给定\(a,b,c\)三个数,可以进行两个操作:1.把一个数+2:2.把任意两个数+1.求最少需要几 ...

  8. AtCoder Regular Contest 095

    AtCoder Regular Contest 095 C - Many Medians 题意: 给出n个数,求出去掉第i个数之后所有数的中位数,保证n是偶数. \(n\le 200000\) 分析: ...

  9. AtCoder Regular Contest 102

    AtCoder Regular Contest 102 C - Triangular Relationship 题意: 给出n,k求有多少个不大于n的三元组,使其中两两数字的和都是k的倍数,数字可以重 ...

随机推荐

  1. Design2:使用HierarchyID构建数据的分层结构

    1,传统的分层结构是父子结构,表结构中有一个ParentID字段自引用表的主键,表示“归属”关系,例如 create table dbo.emph ( ID int not null primary ...

  2. SpringBoot日记——按钮的高亮和添加篇

    场景如下: 我们点击主页,主页那个按钮就高亮: 我们点击员工,员工那个按钮就高亮: 高亮的处理 直接来看代码如何编写: 1.先看一下官方文档如何编写关于参数配置的,等下我们来解释为何这么写: 所以,我 ...

  3. 180813-Spring之RestTemplate使用小结一

    Spring之RestTemplate使用小结 作为一个Java后端,需要通过HTTP请求其他的网络资源可以说是一个比较常见的case了:一般怎么做呢? 可能大部分的小伙伴直接捞起Apache的Htt ...

  4. webgl绘制粗线段

    webgl1不支持设置线段宽度,这就只好通过shader来实现了,参考了踏得网的例子,引用地址:http://wow.techbrood.com/fiddle/43140.先在此感谢踏得网创始人之一 ...

  5. 五、Django之视图和模板-Part 3

    一.概述 一个视图就是一个页面,通常提供特定的功能,使用特定的模版.列如:在一个博客应用中,你可能会看到下列视图: 博客主页:显示最新发布的一些内容 每篇博客的详细页面:博客的永久链接 基于年的博客页 ...

  6. 自动分配ip的方法- 【Linux】

    1.  查看本机无线网络使用的网卡 2.  设置vbox的网络连接为桥接,并选择本机无线网络对应的网卡 3.  进入系统,输入ifconfig命令,记录下系统的HWaddr 4.  修改系统ip配置文 ...

  7. 回顾下TCP/IP协议

    首先要知道什么是TCP/IP协议,从字面意思来看TCP是“Transmission Control Protocol”的缩写,也就是传输控制协议.IP是“Internet Protocol”的缩写,即 ...

  8. Linux 文件搜索命令:find、which、whereis 和 locate

    Linux 提供了许多用于文件搜索的命令,这些命令都很强大,但是也有一些不同之处,这里分别介绍一下. 一.find 命令 find 是最常见和最强大的一个文件搜索命令.使用 find 命令可以在指定目 ...

  9. Cocos2d-x的跨平台原理

    为了充分发挥硬件性能,手机游戏通常使用Native App开发模式,这就造成开发商要为iOS 和Android平台用户开发不同的应用,无论是产品迭代还是运行维护都非常麻烦.Cocos2d-x在iOS, ...

  10. pssh命令详解

    基础命令学习目录首页 原文链接:https://www.cnblogs.com/kevingrace/p/6378719.html pssh提供OpenSSH和相关工具的并行版本.包括pssh,psc ...