ABC393D题解
大概评级:黄。
签到题。
显然,我们需要找到所有的 \(1\) 的位置,然后看其它的 \(1\) 靠拢过来需要几次操作,然后对于每个位置的答案取个最小值就好了。
直接暴力肯定是不行的,考虑优化计算其它的 \(1\) 靠拢过来需要几次操作的过程,首先为了方便,我们将当前位置设为 \(i\),将 \(i\) 左边的 \(1\) 的位置组成的集合称为 \(a\),将 \(i\) 右边的 \(1\) 的位置组成的集合称为 \(b\),集合 \(a\) 的大小称为 \(as\),集合 \(b\) 的大小称为 \(bs\),那么集合 \(a\) 的贡献就是:
\]
\]
至于一开始的式子为什么还要减去 \(as-j\) 是因为每次 \(i\) 左边的一个 \(1\) 靠拢过来后,下一个 \(1\) 靠拢过来需要的次数就会少 \(1\)。
继续正题,我们发现这个式子化简后是可以使用两个前缀和维护的。
额……其实集合 \(b\) 贡献也是差不多的:
\]
\]
可以用两个后缀和维护。
十年 OI 一场空,不开 long long 见祖宗。
总时间复杂度:\(O(N+N) = O(N)\)。
代码:
#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N = 5e5+5;
char a[N];
int sum1[N];
int sum2[N];
signed main()
{
	int n;
	scanf("%lld",&n);
	scanf("%s",a+1);
	for(int i = n;i;i--)
	{
		sum1[i] = sum1[i+1]+(a[i] == '1');
		sum2[i] = sum2[i+1]+(a[i] == '1')*i;
	}
	int minn = 1e18;
	int pre1 = 0,pre2 = 0;
	for(int i = 1;i<=n;i++)
	{
		pre1+=(a[i] == '1');
		pre2+=(a[i] == '1')*i;
		if(a[i] == '1')
		{
			minn = min(minn,(pre1-1)*i-(pre2-i)-(pre1-1)-(pre1-1)*(pre1-2)/2+(sum2[i]-i)-(sum1[i]-1)*i-(sum1[i]-1)-(sum1[i]-1)*(sum1[i]-2)/2);
		}
	}
	printf("%lld",minn);
	return 0;
}
												
											ABC393D题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
		
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
 - noip2016十连测题解
		
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
 - BZOJ-2561-最小生成树 题解(最小割)
		
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
 - Codeforces Round #353 (Div. 2) ABCDE 题解 python
		
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
 - 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
		
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
 - 2016ACM青岛区域赛题解
		
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
 - poj1399 hoj1037 Direct Visibility 题解 (宽搜)
		
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
 - 网络流n题 题解
		
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
 - CF100965C题解..
		
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
 - JSOI2016R3 瞎BB题解
		
题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...
 
随机推荐
- [Blazor] 一文理清 Blazor Identity 鉴权验证
			
一文理清 Blazor Identity 鉴权验证 摘要 在现代Web应用程序中,身份认证与授权是确保应用安全性和用户数据保护的关键环节.Blazor作为基于C#和.NET的前端框架,提供了丰富的身份 ...
 - AI视频抠图来了!还可以替换视频背景,附下载链接
			
虽然人工智能正在飞速发展中,图像处理技术也在不断升级,但视频背景去除一直都是图像处理任务中最具挑战性的难题之一 Clipper是一款专注于高精度图像分割的AI工具,用于图像和视频的背景去除,允许用户直 ...
 - Qt可视化大屏电子看板系统全平台效果图
 - 基于开源IM即时通讯框架MobileIMSDK:RainbowChat-iOS端v9.0版已发布
			
关于MobileIMSDK MobileIMSDK 是一套专门为移动端开发的开源IM即时通讯框架,超轻量级.高度提炼,一套API优雅支持 UDP .TCP .WebSocket 三种协议,支持 iOS ...
 - 基于Netty的IM聊天加密技术学习:一文理清常见的加密概念、术语等
			
1.引言 在社区中,分享了很多篇基于Netty编写的IM聊天入门文章(比如<跟着源码学IM>系列.<基于Netty,从零开发IM>系列等),在这些文章中分享了各种IM通信算法原 ...
 - Python 虚拟环境:原理解析与最佳实践
			
从一个困境说起 小王最近遇到了一个棘手的问题:他在维护两个 Python 项目,一个是去年开发的数据分析系统,依赖 TensorFlow 1.x:另一个是最近在做的预测模型,需要用到 TensorFl ...
 - Note -「基本子串结构」速通笔记
			
学习自 crashed 的<一类基础子串数据结构>摘抄及注解, 略过了一些 crashed 口中 "用不上" 的东西. 这里是速通笔记, 希望快速学习技巧的读者可以 ...
 - Solution -「Gym 101630J」Journey from Petersburg to Moscow
			
\(\mathscr{Description}\) Link. 给定含有 \(n\) 个点 \(m\) 条边的带权无向图,一条路径的长度定义为其中前 \(k\) 大的边权和,求 \(1\) 到 ...
 - Flutter的一些概念(二)
			
注:本文同步发布于微信公众号:stringwu的互联网杂谈 Flutter的一些概念(二) 1 flutter的核心渲染模块 当应用启动时flutter 会遍历所有的Widget 形成Widget 树 ...
 - 十四款常见的Web前端开发框架
			
在做web开发的时候经常会遇到一个问题,那就是,选择什么样的框架来做前端开发.下面封程中把目前常用的一些前端的框架简单的给大家介绍一下. 1. BootstrapBoostrap绝对是目前最流行用得最 ...