传送门

题意:

就是说给你一个由0或1组成的字符串,让你找出来一个0的数量和1的数量相等的最长子字符串和最长子序列

题解:

可以把0当作-1,把1当作1来计算字符串的前缀和

这样的话,当两个位置的前缀和的值相同的时候,那么这两个位置中间的部分就满足题意,除此之外前缀和为0的地方也满足题意

因为这是前缀和,当两个位置前缀和相同就可以让后一个减去前一个前缀和,那么这中间一段便是0和1相同的长度

为了防止出现负数下标,可以让计算出来的前缀和加上一个大正数

代码一:

 1 #include<stdio.h>
2 #include<string.h>
3 #include<stdlib.h>
4 #include<algorithm>
5 using namespace std;
6 char a[100005];
7 int ans[200005][2];
8 int sum[100005];
9 int main()
10 {
11 int n;
12 int s1=0,s0=0,maxx=0;
13 sum[0]=0;
14 scanf("%d",&n);
15 scanf("%s",a);
16 ans[100000][0]=-1;
17 for(int i=0;i<n;i++)
18 {
19 if(a[i]=='1')
20 {
21 s1++;
22 sum[i]=sum[i-1]+1;
23 }
24 else
25 {
26 s0++;
27 sum[i]=sum[i-1]-1;
28 }
29 if(ans[sum[i]+100000][0]==0)
30 {
31 ans[sum[i]+100000][0]=i;
32 }
33 else
34 {
35 ans[sum[i]+100000][1]=i;
36
37 maxx=max(maxx,ans[sum[i]+100000][1]-ans[sum[i]+100000][0]);
38 }
39 }
40 if(s0==s1)
41 {
42 printf("%d %d\n",s0+s1,s0+s1);
43 }
44 else if(s0<s1)
45 {
46 printf("%d %d\n",maxx,s0*2);
47 }
48 else if(s0>s1)
49 {
50 printf("%d %d\n",maxx,s1*2);
51 }
52 return 0;
53 }

代码二:

 1 #include <bits/stdc++.h>
2
3 #define ll long long
4
5 using namespace std;
6
7 const int N=1e5+10;
8
9 int pre[2*N];
10
11 char s[N];
12
13 int main(void)
14
15 {
16
17 int n,sum=0,cnt0=0,cnt1=0,ans=0;
18
19 scanf("%d%s",&n,s+1);
20
21 for(int i=1;i<=n;i++)
22
23 {
24
25 if(s[i]=='0') cnt0++,sum++;
26
27 else cnt1++,sum--;
28
29 if(sum==0)
30
31 {
32
33 if(ans<i) ans=i;
34
35 continue;
36
37 }
38
39 if(pre[sum+n]==0) pre[sum+n]=i;
40
41 else if(i-pre[sum+n]>ans)
42
43 ans=i-pre[sum+n];
44
45 }
46
47 printf("%d %d\n",ans,min(cnt0,cnt1)*2);
48
49 return 0;
50
51 }

H题:

原文:https://blog.csdn.net/code92007/article/details/97305323

给你N(N为偶数且N<=1e3)个不同的点(xi,yi),|xi|,|yi|<=1e3
要求你输出两个整点,使之确定的直线,将平面划成两部分后,一边恰有一半
 
考虑按y增序排,y相同按x增序,也就是处理二维偏序的排序方式,
如果过n/2和n/2+1两个点的中点,画一条斜率为负,但近似水平的线,是可以将上下剖开的
但这个中点可能不是整点,所以直接用n/2和n/2+1两个点平移,
一个左移1e8单位,一个右移1e8单位,从而将直线拉平
但n/2和n/2+1两个点可能位于同一水平线上,这个时候,
左边的点再上移1单位,右边的点下移1单位,就可以使原来的两个点不重合了
 
代码:
 1 #include<bits/stdc++.h>
2
3 using namespace std;
4
5 const int N=1e3+5;
6
7 const int off=1e8;
8
9 int t,n;
10
11 struct node
12
13 {
14
15 int x,y;
16
17 }e[N],c,d;
18
19 bool operator<(node a,node b)
20
21 {
22
23 return a.y<b.y||(a.y==b.y&&a.x<b.x);
24
25 }
26
27 int main()
28
29 {
30
31 scanf("%d",&t);
32
33 while(t--)
34
35 {
36
37 scanf("%d",&n);
38
39 for(int i=1;i<=n;++i)
40
41 scanf("%d%d",&e[i].x,&e[i].y);
42
43 sort(e+1,e+n+1);
44
45 c=e[n/2];d=e[n/2+1];
46
47 if(c.y==d.y)printf("%d %d %d %d\n",c.x+off,c.y-1,d.x-off,d.y+1);
48
49 else printf("%d %d %d %d\n",c.x+off,c.y,d.x-off,d.y);
50
51 }
52
53 return 0;
54
55 }

2019牛客暑期多校训练营(第三场)B题、H题的更多相关文章

  1. 2019牛客暑期多校训练营(第三场)H题目

    题意:给你一个N×N的矩阵,求最大的子矩阵 满足子矩阵中最大值和最小值之差小于等于m. 思路:这题是求满足条件的最大子矩阵,毫无疑问要遍历所有矩阵,并判断矩阵是某满足这个条件,那么我们大致只要解决两个 ...

  2. 2019牛客暑期多校训练营(第三场)- F Planting Trees

    题目链接:https://ac.nowcoder.com/acm/contest/883/F 题意:给定n×n的矩阵,求最大子矩阵使得子矩阵中最大值和最小值的差值<=M. 思路:先看数据大小,注 ...

  3. 2019牛客暑期多校训练营(第三场) F.Planting Trees(单调队列)

    题意:给你一个n*n的高度矩阵 要你找到里面最大的矩阵且最大的高度差不能超过m 思路:我们首先枚举上下右边界,然后我们可以用单调队列维护一个最左的边界 然后计算最大值 时间复杂度为O(n*n*n) # ...

  4. 2019牛客暑期多校训练营(第九场)A:Power of Fibonacci(斐波拉契幂次和)

    题意:求Σfi^m%p. zoj上p是1e9+7,牛客是1e9:  对于这两个,分别有不同的做法. 前者利用公式,公式里面有sqrt(5),我们只需要二次剩余求即可.     后者mod=1e9,5才 ...

  5. 2019牛客暑期多校训练营(第一场)A题【单调栈】(补题)

    链接:https://ac.nowcoder.com/acm/contest/881/A来源:牛客网 题目描述 Two arrays u and v each with m distinct elem ...

  6. 2019牛客暑期多校训练营(第一场) B Integration (数学)

    链接:https://ac.nowcoder.com/acm/contest/881/B 来源:牛客网 Integration 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 5242 ...

  7. 2019牛客暑期多校训练营(第一场) A Equivalent Prefixes ( st 表 + 二分+分治)

    链接:https://ac.nowcoder.com/acm/contest/881/A 来源:牛客网 Equivalent Prefixes 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/ ...

  8. 2019牛客暑期多校训练营(第二场)F.Partition problem

    链接:https://ac.nowcoder.com/acm/contest/882/F来源:牛客网 Given 2N people, you need to assign each of them ...

  9. 2019牛客暑期多校训练营(第一场)A Equivalent Prefixes(单调栈/二分+分治)

    链接:https://ac.nowcoder.com/acm/contest/881/A来源:牛客网 Two arrays u and v each with m distinct elements ...

  10. [状态压缩,折半搜索] 2019牛客暑期多校训练营(第九场)Knapsack Cryptosystem

    链接:https://ac.nowcoder.com/acm/contest/889/D来源:牛客网 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 262144K,其他语言52428 ...

随机推荐

  1. 简要MR与Spark在Shuffle区别

    一.区别 ①本质上相同,都是把Map端数据分类处理后交由Reduce的过程. ②数据流有所区别,MR按map, spill, merge, shuffle, sort, r educe等各阶段逐一实现 ...

  2. mysql—group_concat函数

    MySQL中的group_concat函数的使用方法,比如select group_concat(name) . 完整的语法如下: group_concat([DISTINCT] 要连接的字段 [Or ...

  3. 【葵花宝典】一天掌握Docker

    第1章Docker 概述 1-1 Docker是什么 没有虚拟化技术的原始年代 我们仔细想想,在没有计算虚拟化技术的"远古"年代,如果我们要部署一个应用程序(Application ...

  4. 输入12V,输出12V的限流芯片

    随着手机充电电流的提升,和设备的多样化,USB限流芯片就随着需求的增加而越来越多,同时为了更好的保护电子设备,需要进行一路或者多路的负载进行限流. USB限流芯片,5V输入 1, PW1502,常使用 ...

  5. 微服务网关1-Spring Cloud Gateway简介

    一.网关基本概念 1.API网关介绍 ​ API 网关出现的原因是微服务架构的出现,不同的微服务一般会有不同的网络地址,而外部客户端可能需要调用多个服务的接口才能完成一个业务需求,如果让客户端直接与各 ...

  6. Kafka分区分配策略(Partition Assignment Strategy)

    众所周知,Apache Kafka是基于生产者和消费者模型作为开源的分布式发布订阅消息系统(当然,目前Kafka定位于an open-source distributed event streamin ...

  7. Elasticsearch从入门到放弃:浅谈算分

    今天来聊一个 Elasticsearch 的另一个关键概念--相关性算分.在查询 API 的结果中,我们经常会看到 _score 这个字段,它就是用来表示相关性算分的字段,而相关性就是描述一个文档和查 ...

  8. Xamarin.Forms: 无限滚动的ListView(懒加载方式)

    说明 在本博客中,学习如何在Xamarin.Forms应用程序中设计一个可扩展的无限滚动的ListView.这个无限滚动函数在默认的Xamarin.Forms不存在,因此我们需要为此添加插件.在这里我 ...

  9. Frame of Reference and Roaring Bitmaps

    https://www.elastic.co/cn/blog/frame-of-reference-and-roaring-bitmaps http://roaringbitmap.org/ 2015 ...

  10. Enables DNS lookups on client IP addresses 域名的分层结构

    虚拟域名访问,路由可以到达,但无输出. http://httpd.apache.org/docs/2.2/mod/core.html#hostnamelookups 移动解析 HttpDNS_域名解析 ...