牛客NOIP暑期七天营-普及组1 解题报告
A
对于\(100\%\),直接开个桶统计即可。入门题目。
代码:https://ac.nowcoder.com/acm/contest/view-submission?submissionId=41153707&scrollToDetail=1
B
对于\(100\%\),直接按题目模拟就好。每次两个指针扫一下就是\(O(n)\)的了。整个加起来是\(O(\max(n,len)\times m)\)的复杂度。可以结合代码理解。
代码:https://ac.nowcoder.com/acm/contest/view-submission?submissionId=41153710
C
对于\(10\%\)直接copy代码然后完善一下头文件什么的就行了。
考虑这个\(dp\)是在干什么,其实就是求对于每个位置往前的前\(k\)大的数的和。
那么对于\(40\%\),直接删掉第三重循环(考虑如果不选这个数,可以直接直接从\(f[i-1][j]\)转移,所以第三重循环完全多余)
对于\(100\%\),用一个数据结构动态维护前\(k\)大即可。(这里用\(set\)或者小根堆,都行)
复杂度\(O(n\log n)\)
代码:https://ac.nowcoder.com/acm/contest/view-submission?submissionId=41153712
D
对于\(10\%\),很明显是个\(O(n^6 )\)的算法..那么直接暴力枚举两个端点,然后暴力统计和取\(\max\)即可。
对于\(30\%\),注意到这个矩阵的生成方式有点特别,把它写出来,就会发现一个矩阵的和是一段\(a_i\)乘上一段\(b_j\),那么便可以省去统计两重循环,复杂度\(O(n^4)\)
对于\(50\%\),考虑优化\(30\)分的做法,30分的统计就是一个前缀和相乘的形式,那么要让它最大无非3种情况,正数最大\(\times\)正数最大,负数最小\(\times\)负数最小,正数最小\(\times\)负数最大,第三种又可以分为正数最小在\(A\)中,正数最小在\(B\)中两种情况,于是维护前缀\(\max\)和前缀\(\min\),分类讨论一下,就可以\(O(n^2)\)解决了。
对于\(100\%\),既然是一段\(a_i\)乘上一段\(b_j\),那么分别统计最大子段和和最小子段和即可。
最后根据\(50\%\)的做法分四类情况讨论一下就好。这部分其实就是把\(30\)和\(50\)分做法综合起来而已。
复杂度$O(n) $
至于怎么算最小子段和?全部取反求最大子段和再重新重新乘\(-1\)即可。
代码:https://ac.nowcoder.com/acm/contest/view-submission?submissionId=41153727
牛客NOIP暑期七天营-普及组1 解题报告的更多相关文章
- 牛客NOIP暑期七天营-提高组1 解题报告
https://ac.nowcoder.com/acm/contest/920#question A 构造+双指针 发现m的限制是1e5,而点数是5e4,所以不能构造太多的边,思考一下最短路树的定义. ...
- 牛客NOIP暑期七天营-普及组2D
链接:https://ac.nowcoder.com/acm/contest/926/D来源:牛客网 在一维坐标系中,给定 n条有颜色的线段,第 i条线段的左右端点分别为 li和 ri,此外它的颜 ...
- 牛客NOIP暑期七天营-提高组1
牛客NOIP暑期七天营-提高组1 链接 A 边权可为0就排序建一条链子. 但是边权不为0 除了第一个有0的不行. x连向上一个比他小的数. 期间判断有无解. #include <bits/std ...
- 牛客NOIP暑期七天营-提高组5+普及组5
————提高组———— 第一题:deco的abs 题目链接:https://ac.nowcoder.com/acm/contest/934/A 因为每个数都可以加任意次 d ,所以可以推出 0 < ...
- 牛客NOIP暑期七天营-提高组6
目录 A-积木大赛 题目描述 link 题解 代码 B-破碎的序列 题目描述 link 题解 C-分班问题 题目描述 link 题解 比赛链接 官方题解 A-积木大赛 题目描述 link 题解 标签: ...
- 牛客NOIP暑期七天营-提高组3
第一题:破碎的矩阵 题目链接:https://ac.nowcoder.com/acm/contest/932/A 刚看到这题的时候感觉特别熟悉...诶,这不就是codeforces某场比赛的某某 ...
- 牛客NOIP暑期七天营-提高组2
第一题:ACGT 题目链接:https://ac.nowcoder.com/acm/contest/931/A trie树.hash.map遍历 ①.trie树上的节点多记一个rest值表示还有多少 ...
- 牛客NOIP暑期七天营-提高组6C:分班问题 (组合数)
题意:A班有N个人,B班有M个人,现在要组成一个新的班级C班,为了公平,从AB班各抽相同人数的人. 现在求所有方案中,人数之和是多少. 思路:即求Σ k*C(N,k)*C(M,k); 先忽略这个 ...
- 牛客NOIP暑期七天营-提高组5
A:deco的abs. 水题,先%,然后相邻两个数min()一下差值. #include<bits/stdc++.h> #define ll long long using namespa ...
随机推荐
- Activiti6.0流程编辑器汉化教程(en.json文件汉化)
{ "GENERAL": { "MAIN-TITLE": "Activiti", "ERROR": { "GE ...
- 修复一个mysqlbinlog_flashback不支持json格式问题
修复一个mysqlbinlog_flashback不支持json格式问题 , 有问题可以反馈留言 , 如下盘: 最简单的例子为 python mysqlbinlog_back.py --host=&q ...
- Linux定时自动备份oracle数据库
1.在服务器创建备份目录,并赋予权限mkdir -p /backup/P_DATA #新建shell脚本存放路径mkdir -p /backup/P_DB_BACK #新建Oracle数据库备份目录 ...
- 系统中提示未找到/usr/bin/ld: cannot find -lxxx错误的通用解决方法
在linux环境编译应用程式或lib的source code时常常会出现如下的错误讯息: 代码如下: /usr/bin/ld: cannot find -lxxx 这些讯息会随着编译不同类型的sour ...
- (五)linux 学习 --重定向
The Linux Command Line 读书笔记 - 部分内容来自 http://billie66.github.io/TLCL/book/chap07.html 文章目录 标准输入.输出.错误 ...
- day31——recv工作原理、高大上版解决粘包方式、基于UDP协议的socket通信
day31 recv工作原理 源码解释: Receive up to buffersize bytes from the socket. 接收来自socket缓冲区的字节数据, For the opt ...
- 【Linux】一步一步学Linux——Centos7.5安装图解(08)
00. 目录 参考博客:https://mp.csdn.net/mdeditor/95031775# 01. Centos7.5简介 CentOS(Community Enterprise Opera ...
- Django-model更上层楼
一 QuerySet对象 1.1可切片 使用Python 的切片语法来限制查询集记录的数目 .它等同于SQL 的LIMIT 和OFFSET子句. Entry.objects.all()[:5] # ( ...
- 『Go基础』第8节 格式化输出
输出就是将数据信息打印到电脑屏幕上. 本节我们就来学习一下Go语言中的三种输出方式: Print().Println().Printf(). 1.Print() Print()主要的一个特点就是打印数 ...
- python爬虫-80电子书,爬图片
''' 作者:Caric_lee 日期:2018 查看图片 ''' import requests from bs4 import BeautifulSoup r = requests.get(&qu ...