疫情当下,美帝又开始倒牛奶了,这一幕似曾相识啊~~~

这个题目非常的应景,又是美国佬的奶牛

【题目地址】

【一句话题意】

N头牛排成一列1<=N<=5000。每头牛或者向前或者向后。

为了让所有牛都 面向前方,农夫每次可以将K头连续的牛转向1<=K<=N,

求操作的最少次数M和对应的最小K。

【Input】

第1行:单个整数:N

第2..N + 1行:第i + 1行包含单个字符F或B,指示母牛i面向前还是面向后。

【Output】

第1行:两个以空格分隔的整数:K和M

【Sample】

input
7
B
B
F
B
F
B
B
output
3 3

【分析&思路】

区间修改?

线段树、树状数组,暴力枚举01修改——boom

我们注意到每一个点只有两种状态0|1

那么如果修改两次的话就相当于没改咯

我们把区间分开考虑

怎么说

就是把最左边连续的一段进行操作变为全部向前

于是在后续的操作中我们duck不必再考虑前面的

这思路没啥问题,直接上暴力

#include <cstdio>
using namespace std;
int n, a[5005][5005], minn = 99999, step , pin; int main(){
scanf("%d",&n);
for(int i = 1; i <= n; i++){
char ch;
getchar();
ch = getchar();
if(ch == 'B') a[0][i] = 0;
else a[0][i] = 1;
}
for(int i = 1; i <= n; i++){
step = 0;
int flag = 0;
for(int j = 1; j <= n; j++)
a[i][j] = a[0][j];
for(int j = 1; j <= n - i + 1; j++){
if(!a[i][j]){
for(int k = 0; k < i ; k++){
a[i][j + k] ^= 1;
}
step++;
if(step > minn) break;
}
}
for(int j = n - i + 2; j <= n; j++){
if(!a[i][j]){
flag = 1;
break;
}
}
for(int j = 1; j <= n; j++)
if(!flag) {
if(minn > step)
{
minn = step;
pin = i;
}
}
}
printf("%d %d", pin, minn);
return 0;
}

然后……T掉了……

那么我们再来考虑优化的方法

类似于差分

在此,可能叫做“异或分”

记录区间长度为k

每次反转的时候更改标记为0或1

给两个区间分别异或

则不改变前后区间的相对状态

总的时间复杂度为\(O(n^2)\)

emmmmm就这样叭

代码非原创

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int maxn = 10009;
int n;
bool A[maxn],B[maxn];
int main(){
scanf("%d",&n);
char ch;
for(int i=1;i<=n;++i){
cin>>ch;A[i]=ch=='B'?0:1;
}
int mincnt=0x7fffffff,anslen;
for(int len=1;len<=n;++len){
memset(B,0,sizeof B);
bool b=0,flag=1;int cnt=0;//flag记录当前长度是否有解
for(int i=1;i<=n;++i){//因为区间翻转只有状态0和1,所以用^代替+和-
b^=B[i];//数组B为记录差分的数组
if(!(A[i]^b)){//若当前位置为0
if(i+len-1>n){flag=0;break;}//唯一的失败条件:一次翻转的长度大于剩余的长度
b^=1,B[i+len]^=1;
++cnt;
}
}
if(flag){if(cnt<mincnt)mincnt=cnt,anslen=len;}
}printf("%d %d\n",anslen, mincnt);
}

USACO07 MAR Face The Right Way G的更多相关文章

  1. Linux上的文件查找工具之locate与find

    前言 Linux上提供了两款工具用于查找文件,一款是locate,另一款是find. locate的特点是根据已生成的数据库查找,速度较快,但是查找的是快照数据,不准确. 因此在日常使用中,为了准确性 ...

  2. Computer Vision_33_SIFT:An efficient SIFT-based mode-seeking algorithm for sub-pixel registration of remotely sensed images——2015

    此部分是计算机视觉部分,主要侧重在底层特征提取,视频分析,跟踪,目标检测和识别方面等方面.对于自己不太熟悉的领域比如摄像机标定和立体视觉,仅仅列出上google上引用次数比较多的文献.有一些刚刚出版的 ...

  3. Storyboards Tutorial 03

    这一节主要介绍segues,static table view cells 和 Add Player screen 以及 a game picker screen. Introducing Segue ...

  4. 文件图标SVG

    ​<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink ...

  5. [BZOJ1659][Usaco2006 Mar]Lights Out 关灯

    [BZOJ1659][Usaco2006 Mar]Lights Out 关灯 试题描述 奶牛们喜欢在黑暗中睡觉.每天晚上,他们的牲口棚有L(3<=L<=50)盏灯,他们想让亮着的灯尽可能的 ...

  6. BZOJ1638: [Usaco2007 Mar]Cow Traffic 奶牛交通

    1638: [Usaco2007 Mar]Cow Traffic 奶牛交通 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 571  Solved: 199 ...

  7. BZOJ 1616: [Usaco2008 Mar]Cow Travelling游荡的奶牛( dp )

    一道水 dp ...然后我一开始用 BFS ...结果 MLE 了... dp[ i ][ j ][ k ] 由它四个方向上的 k - 1 转移. -------------------------- ...

  8. BZOJ 3373: [Usaco2004 Mar]Lying Livestock 说谎的牲畜( 差分约束 )

    枚举每头牛, 假设它在说谎, 建图判圈就行了...为啥水题都没人来写.. --------------------------------------------------------------- ...

  9. 1638: [Usaco2007 Mar]Cow Traffic 奶牛交通

    1638: [Usaco2007 Mar]Cow Traffic 奶牛交通 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 618  Solved: 217 ...

随机推荐

  1. Mysql添加索引及索引的优缺点

    一.什么是索引? 索引是对数据库表中的一列或多列值进行排序的一种结构,使用索引可以快速访问数据库表中的特定信息. 二.索引的作用? 索引相当于图书上的目录,可以根据目录上的页码快速找到所需的内容,提高 ...

  2. 容器技术之Dockerfile(三)

    前面我们聊到了dockerfile的 FROM.COPY .ADD.LABAL.MAINTAINER.ENV.ARG.WORKDIR.VOLUME.EXPOSE.RUN.CMD.ENTRYPOINT指 ...

  3. SmokePing 快速搭建

    SmokePing介绍 smokeping是来监控IDC机房网络质量情况,可以从监控图上的延时与丢包情况分辨出机房的网络是否稳定,是否为多线,是否为BGP机房以及到各城市的三个运行商网络各是什么情况. ...

  4. 构建操作mysql的类

    <?phpclass PdoMySQL{ public static $config=array();//设置连接参数,配置信息 public static $link=null;//保存连接标 ...

  5. ecshop php商城系统数据库结构及表的介绍分析

      ecshop共86张表,确实比较多,不过功能确实最完善的. 表结构分析 ecs_account_log // 用户账目日志表 ecs_activity // 活动表(代码,名称,开始,结束,描述) ...

  6. [每日一题2020.06.13]leetcode #739 #15 单调栈 双指针查找

    739 每日温度 ( 单调栈 ) 题目 : https://leetcode-cn.com/problems/daily-temperatures/ 题意 : 找到数组每一个元素之后第一个大于它的元素 ...

  7. centos7 hadoop 单机模式安装配置

    前言 由于现在要用spark,而学习spark会和hdfs和hive打交道,之前在公司服务器配的分布式集群,离开公司之后,自己就不能用了,后来用ambari搭的三台虚拟机的集群太卡了,所以就上网查了一 ...

  8. (八)跑完用例后通过maven发送邮件

    邮件类: package config; import com.sun.mail.util.MailSSLSocketFactory; import org.apache.log4j.Logger; ...

  9. CentOS Linux release 7.7.1908 (Core)--rabbitmq安装

    1.连接服务器,输入账号和密码,密码输入的时候是看不见的,只管输就行,然后回车. 2.安装Erlang,RabbitMQ是用这门语言写的,所以要安装他. 3.安装filezilia就是win和linu ...

  10. uiautomatorviewer 截取手机屏幕报错

    1. 解决办法: 1.在e盘新建一个文件夹,命名为app.uix 2.打开cmd命令,输入命令adb pull /sdcard/app.uix E:/app.uix 3.打开uiautomatorvi ...