常州模拟赛d8t2 绘画



分析:考虑记录每个坐标上每个颜色出现了几次,并由此算出每个颜色在这个坐标上的贡献。答案肯定是原图的答案扣去矩形的答案,再加上那个矩形同种颜色的贡献,这里的答案指的是Σdis.我们先要记录每个颜色在各个位置出现的次数,因为每一次都是区间操作嘛,所以我们用二维差分可以很好地维护,前缀和求出出现的次数. 然后求出每个位置原本图的和副本的差距,求一下前缀和就得到原本图整体的答案.
最后再用一个前缀和数组求出每个位置覆盖为颜色x后的贡献,就可以了.
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <cmath> #define s(u,i,j,k,l) (u[k][l] - u[i-1][l] - u[k][j-1] + u[i - 1][j-1])
using namespace std; const int maxn = ,maxm = ;
int n, m, kk, rubbish,a[maxn][maxn],sum[][maxn][maxn],col[maxm];
int x3[maxm], y3[maxm], x4[maxm], y4[maxm];
long long ans[maxn][maxn],b[][maxn][maxn],ret = 1LL << ,pi;
char s[maxn]; long long S1(int x, int y, int x2, int y2)
{
return ans[x2][y2] - ans[x - ][y2] - ans[x2][y - ] + ans[x - ][y - ];
} long long S2(int cur, int x, int y, int x2, int y2)
{
return b[cur][x2][y2] - b[cur][x - ][y2] - b[cur][x2][y - ] + b[cur][x - ][y - ];
} int main()
{
scanf("%d%d%d%d", &n, &m, &kk, &rubbish);
for (int i = ; i <= n; i++)
{
scanf(" %s", s + );
for (int j = ; j <= m; j++)
a[i][j] = s[j] - 'a';
}
for (int i = ; i <= kk; i++)
{
scanf("%d%d%d%d %c", &x3[i], &y3[i], &x4[i], &y4[i], &col[i]);
col[i] -= 'a';
++sum[col[i]][x3[i]][y3[i]]; //二维差分修改每种颜色出现的次数
--sum[col[i]][x3[i]][y4[i] + ];
--sum[col[i]][x4[i] + ][y3[i]];
++sum[col[i]][x4[i] + ][y4[i] + ];
}
for (int k = ; k < ; k++)
for (int i = ; i <= n; i++)
for (int j = ; j <= m; j++)
sum[k][i][j] += sum[k][i - ][j] + sum[k][i][j - ] - sum[k][i - ][j - ];//统计每个点每种颜色出现的次数
for (int i = ; i <= n; i++)
for (int j = ; j <= m; j++)
{
for (int k = ; k < a[i][j]; k++)
ans[i][j] += sum[k][i][j] * (a[i][j] - k);//每一位对dis的贡献值
for (int k = ; k > a[i][j]; k--)
ans[i][j] += sum[k][i][j] * (k - a[i][j]);
ans[i][j] += ans[i - ][j] + ans[i][j - ] - ans[i - ][j - ];//记录整个图的dis
}
for (int i = ; i <= n; i++)
for (int j = ; j <= m; j++)
{
int t = ;
for (int k = ; k < ; k++)
t += sum[k][i][j];
sum[a[i][j]][i][j] += kk - t;//之前记录的是副本上出现的次数,现在记录原有的出现次数
}
for (int i = ; i <= n; i++)
for (int j = ; j <= m; j++)
{
int s1 = , s2 = ;
for (int k = ; k < ; k++)
{
s1 += sum[k][i][j] * k;
s2 += sum[k][i][j];
b[k][i][j] = s2 * k - s1; //如果我把每个副本(i,j)上的点全部变成k的贡献
}
s1 = s2 = ;
for (int k = ; k >= ; k--)//相当于计算ans,倒着计算一次
{
s1 += sum[k][i][j] * k;
s2 += sum[k][i][j];
b[k][i][j] += s1 - s2 * k;
}
for (int k = ; k < ; k++)
b[k][i][j] += b[k][i - ][j] + b[k][i][j - ] - b[k][i - ][j - ];
}
for (int i = ; i <= kk; i++)
{
long long temp = ans[n][m] - s(ans, x3[i], y3[i], x4[i], y4[i]) + s(b[col[i]], x3[i], y3[i], x4[i], y4[i]);
if (temp < ret)
{
ret = temp;
pi = i;
}
}
printf("%lld %d\n", ret, pi);return ;
}
常州模拟赛d8t2 绘画的更多相关文章
- 常州模拟赛d4t1 立方体
题目描述 立方体有 6 个面,每个面上有一只奶牛,每只奶牛都有一些干草.为了训练奶牛的合作精神,它 们在玩一个游戏,每轮:所有奶牛将自己的干草分成 4 等份,分给相邻的 4 个面上的奶牛. 游戏开始, ...
- 常州模拟赛d7t3 水管
分析:第一问还是很好做的,关键是怎么做第二问.我们可以每次删掉最小生成树上的一条边,然后再求一次最小生成树,看边权和大小和原来的是不是一样的,不过这个做法效率很低. 考虑Kruskal算法的原理,每次 ...
- 常州模拟赛d6t3 噪音
FJ有M个牛棚,编号1至M,刚开始所有牛棚都是空的.FJ有N头牛,编号1至N,这N头牛按照编号从小到大依次排队走进牛棚,每一天只有一头奶牛走进牛棚.第i头奶牛选择走进第p[i]个牛棚.由于奶牛是群体动 ...
- bzoj3743 [Coci2015]Kamp 常州模拟赛d6t2
3743: [Coci2015]Kamp Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 484 Solved: 229[Submit][Status ...
- 常州模拟赛d5t2 mogician
分析:一个暴力的思想是枚举g,然后枚举每个数ai,看能不能符合要求,这样复杂度是O(nA)的,直接T掉了.也没什么其他的办法了,在暴力的基础上优化一下,优化的关键是要如何快速统计出不满足要求的数的个数 ...
- 常州模拟赛d5t1 journalist
分析:出题人丧心病狂卡spfa......只能用dijkstar+堆优化. 主要的难点是字典序的处理上,一个想法是在做最短路的时候处理,边松弛边记录,比个大小记录最佳答案.具体的思路大概和最短路计数差 ...
- 常州模拟赛d4t3 字符串划分
题目描述 给你一串由小写字母组成的字符串,希望你把它划分成一些小段,使得每一小段字符串中的字母 都不相同,并且希望分的段数尽量少. 然后,把这些小段按字典序排序后输出,中间由一个空格分隔. 例如:字符 ...
- 常州模拟赛d4t2 陶陶摘苹果
题目描述 陶陶家的院子里有一棵苹果树,每到秋天树上就会结出 n 个苹果.苹果成熟的时候,陶陶就会 跑去摘苹果. 陶陶的手不能弯 (他仅能把手伸直),当且仅当陶陶达到的高度与苹果的高度相等的时候,陶陶 ...
- 常州模拟赛d3t3 两只怪物心心相印
题目背景 从前我是一位无名的旅人,旅途中我得到了某样东西:贤者之石.我因此得到悠久的时光和漂泊的生命.1897年冬天,我一时兴起舍弃了旅人的生活. 贤者之石创造出来的,是货真价实的黄金.我的名声传遍了 ...
随机推荐
- iOS静态库.Framework制作
首先要解释一下什么是库,库(Library)其实就是一段编译好的二进制代码,加上头文件就可以供别人使用,一般会有两种情况要用到库: 某些代码需要给别人使用,但是我们不希望别人看到源码,就需要以库的形式 ...
- C#封装访问修饰符
C# 封装 封装 被定义为"把一个或多个项目封闭在一个物理的或者逻辑的包中".在面向对象程序设计方法论中,封装是为了防止对实现细节的访问. 抽象和封装是面向对象程序设计的相关特性. ...
- linux学习之路4 系统目录架构
linux树状文件系统结构 bin(binary) 保存可执行文件 也就是保存所有命令 boot 引导目录 保存所有跟系统有关的引导程序 其中Vmlinux文件最为重要,是系统内核 dev 保存所有的 ...
- 题解报告:poj 1321 棋盘问题(dfs)
Description 在一个给定形状的棋盘(形状可能是不规则的)上面摆放棋子,棋子没有区别.要求摆放时任意的两个棋子不能放在棋盘中的同一行或者同一列,请编程求解对于给定形状和大小的棋盘,摆放k个棋子 ...
- System.AppDomain类详解(一)
AppDomain是CLR(Common Language Runtime:公共语言运行库),它可以加载Assembly.创建对象以及执行程序. AppDomain是CLR实现代码隔离的基本机制. 每 ...
- ES6 学习笔记 - 变量的解构赋值
变量的解构赋值 学习资料:ECMAScript 6 入门 数组的解构赋值 基本用法 可以从数组中提取值,按照对应位置,对变量赋值.这种写法属于"模式匹配". let [a, b, ...
- javascript异步下载 Promise实现
一般下载都是直接打开一个链接就行.var URL = 'XXXX';window.open(URL)其实这样会有些问题:1. 浏览器禁止打开新窗口,导致无法下载 那么怎么解决呢?这样: <a h ...
- 关于c++11中static类对象构造函数线程安全的验证
在c++11中,static静态类对象在执行构造函数进行初始化的过程是线程安全的,有了这个特征,我们可以自己动手轻松的实现单例类,关于如何实现线程安全的单例类,请查看c++:自己动手实现线程安全的c+ ...
- 文件和打印共享资源(IP地址)处于联机状态,但未对连接尝试做出响应。
文件和打印共享资源(IP地址)处于联机状态,但未对连接尝试做出响应. 检测到 远程计算机不接受端口 445 上的连接,这可能是由于防火墙或安全策略设置,或因为服务可能暂时不可用.Windows 在计算 ...
- axios方法封装
axios方法封装 一般情况下,我们会用到的方法有:GET,POST,PUT,PATCH,封装方法如下: 五.封装后的方法的使用 1.在main.js文件里引用之前写好的文件,我的命名为htt ...