估分:25+0+60=85

实际:25+0+60=85

T1:

  就只会25的暴力

  分治,到一个区间[l,r],cnt[i]表示i这个颜色在区间内的出现次数,从两头同时扫描,扫描到第一个cnt[i]小于f[r-l+1]后往下走,先继续搜较大的区间,再搜索小区间,返回时把cnt清空,因为已经搜过了就没必要搜了

 1 #include<cstdio>
2 #include<cstring>
3 #include<iostream>
4 #include<algorithm>
5 using namespace std;
6
7 const int N = 1000010;
8
9 int n;
10 int c[N], f[N], cnt[N];
11
12 int ans;
13
14 void dfs(int l, int r)
15 {
16 for (int i = l, j = r; i <= j; i++, j--)
17 {
18 if (cnt[c[i]] < f[r - l + 1])
19 {
20 for (int k = l; k <= i; k++) cnt[c[k]]--;
21 dfs(i + 1, r);
22 for (int k = l; k < i; k++) cnt[c[k]]++;
23 dfs(l, i - 1);
24 return;
25 }
26 if (cnt[c[j]] < f[r - l + 1])
27 {
28 for (int k = r; k >= j; k--) cnt[c[k]]--;
29 dfs(l, j - 1);
30 for (int k = r; k > j; k--) cnt[c[k]]++;
31 dfs(j + 1, r);
32 return;
33 }
34 }
35
36 ans = max(ans, r - l + 1);
37 for (int i = l; i <= r; i++) cnt[c[i]]--;
38 }
39
40 int main()
41 {
42 scanf("%d", &n);
43 for (int i = 1; i <= n; i++) scanf("%d", &c[i]), cnt[c[i]]++;
44 for (int i = 1; i <= n; i++) scanf("%d", &f[i]);
45 dfs(1, n);
46 printf("%d", ans);
47 }

T2:

  可能有个10分的暴力,但没写完

T3:

  因为有一个k的宽容,经过简单的推理过程就能得出答案至少为n-1,60分就到手了,若n=9,构造就这样

  0 1 2 3 4 5 6 7 8

  8 7 6 5 4 2 1 0 3

  a正序,b逆序,把b[n/2+1]挪到最后

  正解:

  当n=4k+2或n=4k+3时就是上面的构造方法,不存在答案为n的构造,证明如下:
  

  当n=4k时,设构造出的排序为a,我们把ai和i连边,就会得到下面这样的环:

  

  当n=4k+1时,可以得到这样的环:

  

  可以看出ai,和bi的差值都是不同的

 1 #include<cstdio>
2 #include<cstring>
3 #include<iostream>
4 #include<algorithm>
5 using namespace std;
6
7 const int N = 1000010;
8
9 int n, k;
10 int t1, t2, p[N], sz;
11 char c[10];
12
13 void write(int x)
14 {
15 if (x < 0) putchar('-'), x = -x;
16 if (x / 10) write(x / 10);
17 putchar(x % 10 + '0');
18 }
19
20 int main()
21 {
22 scanf("%d%d", &n, &k);
23 t1 = 1, t2 = n;
24
25 if ((n & 3) > 1)
26 {
27 for (int i = 1; i <= (n >> 1); ++i)
28 {
29 p[t1] = t2;
30 p[t2] = t1 + 1;
31 t1++, t2--;
32 }
33 p[t1] = 1;
34 }
35 else
36 {
37 for (int i = 1; t1 < t2; ++i)
38 {
39 p[t1] = t2;
40 if (t1 == (n >> 2)) p[t1 + 1] = t1 + 1, ++t1;
41 p[t2] = t1 + 1, ++t1, --t2;
42 }
43 p[t1] = 1;
44 }
45 for (int i = 1; i <= n; ++i) write(i - 1), putchar(' ');
46 puts("");
47 for (int i = 1; i <= n; ++i) write(p[i] - 1), putchar(' ');
48 }

正睿十一A班模拟赛day1的更多相关文章

  1. CH Round #48 - Streaming #3 (NOIP模拟赛Day1)

    A.数三角形 题目:http://www.contesthunter.org/contest/CH%20Round%20%2348%20-%20Streaming%20%233%20(NOIP模拟赛D ...

  2. CH Round #54 - Streaming #5 (NOIP模拟赛Day1)

    A.珠 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2354%20-%20Streaming%20%235%20(NOIP模拟赛Day1)/珠 题解:sb题, ...

  3. 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...

  4. 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...

  5. 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...

  6. 10.17(山东多校联合模拟赛 day1)

    山东多校联合模拟赛 day1 题不难 rect [问题描述] 给出圆周上的 N 个点, 请你计算出以这些点中的任意四个为四个角,能构成多少个矩形. 点的坐标是这样描述的, 给定一个数组 v[1..N] ...

  7. NOI模拟赛 Day1

    [考完试不想说话系列] 他们都会做呢QAQ 我毛线也不会呢QAQ 悲伤ING 考试问题: 1.感觉不是很清醒,有点困╯﹏╰ 2.为啥总不按照计划来!!! 3.脑洞在哪里 4.把模拟赛当作真正的比赛,紧 ...

  8. PKUSC 模拟赛 day1 下午总结

    下午到了机房之后又困又饿,还要被强行摁着看英文题,简直差评 第一题是NOIP模拟赛的原题,随便模拟就好啦 本人模拟功力太渣不小心打错了个变量,居然调了40多分钟QAQ #include<cstd ...

  9. HGOI2010816 (NOIP 提高组模拟赛 day1)

    Day1 210pts(含T1莫名的-10pts和T3莫名的-30pts) 100+70+40=210 rank 29 这道题第一眼看是字符串匹配问题什么KMP啊,又想KMP不会做啊,那就RK Has ...

随机推荐

  1. 焦大:seo思维进化论(上)

    http://www.wocaoseo.com/thread-51-1-1.html seo排名浮动一直是很多人关心的事情,但是背后的原理却一直很少被人知道.在seo是什么里说了seo的核心是什么,我 ...

  2. jQuery入口函数与JavaScript入口函数的区别

    jQuery  的入口函数是在  html  所有标签 (DOM) 都加载之后就会去执行 JavaScript  的  window.onload  时间是等到所有内容,包括外部图片之类的文件加载完成 ...

  3. 使用script打开页面

    <script src="x" onerror=javascript:window.open("http://192.168.38.1/csrf.html" ...

  4. 我用 Java 8 写了一段逻辑,同事直呼看不懂,你试试看。。

    业务背景 首先,业务需求是这样的,从第三方电商平台拉取所有订单,然后保存到公司自己的数据库,需要判断是否有物流信息,如果有物流信息,还需要再进行上传. 而第三方接口返回的数据是 JSON 格式的,其中 ...

  5. docker搭建zabbix收集windows计数器性能数据

    1 docker服务的安装 1)在线安装docker服务 在线安装可以参考下面的安装步骤 a 安装相关依赖组件 yum install -y yum-utils device-mapper-persi ...

  6. 银行应用USB Key身份认证方案

    前言:本文为USB Key的厂商SafeNet公司提供的宣传稿件,并不代表本博客作者的观点和看法. 本文的技术解决方案使用的是SafeNet自身的产品,虽然这个产品支持数字签名和PKI体系,可生成并储 ...

  7. 认证授权:IdentityServer4

    前言 上一篇文章<学习OIDC>介绍了OIDC协议,本篇开始我们就来具体来学习OIDC的具体实现IdentityServer4 学习. 一.IdentityServer4 是什么? Ide ...

  8. C#操作Excel开发报表系列整理

    C#操作Excel进行报表开发系列共写了八篇,也已经有很久没有新东西了,现在整理一下,方便以后查阅,如果有写新的,会同时更新.需要注意的是因为Office的版本不同,实际的代码可能会有所不同,但是都是 ...

  9. Kubernetes 服务部署最佳实践(一) ——如何更好地设置 Request 与 Limit

    如何为容器配置 Request 与 Limit? 这是一个即常见又棘手的问题,这个根据服务类型,需求与场景的不同而不同,没有固定的答案,这里结合生产经验总结了一些最佳实践,可以作为参考. 所有容器都应 ...

  10. basicInterpreter1.02 增加对for循环的支持

    源码下载:https://files.cnblogs.com/files/heyang78/basicInterpreter102-20200531-2.rar 输入: for x= to print ...