出题人好评。

评测机差评。

A 救救喵咪

二位偏序。如果数据范围大的话直接树状数组,不过才1000就\(O(n^2)\)暴力就ok了。

#include <bits/stdc++.h>
struct Node {
int x, y;
}a[1010]; int main() {
int n;
std::cin >> n;
for(int i = 1; i <= n; ++i) {
std::cin >> a[i].x >> a[i].y;
}
for(int i = 1; i <= n; ++i) {
int ans = 0;
for(int j = 1; j <= n; ++j) {
if(a[j].x > a[i].x && a[j].y > a[i].y) ++ans;
}
printf("%d\n", ans);
}
}

B 救救兔子

二分经典题。注意初始化即可。

#include <bits/stdc++.h>

#define N 100010
#define ll long long
#define int long long
ll a[N];
int m, n; ll find_max(ll x) {
int l = 1, r = n, ans = n;
while(l <= r) {
int mid = (l + r) >> 1;
if(a[mid] >= x) ans = mid, r = mid - 1;
else l = mid + 1;
}
return a[ans];
} ll find_min(ll x) {
int l = 1, r = n, ans = 1;
while(l <= r) {
int mid = (l + r) >> 1;
if(a[mid] <= x) l = mid + 1, ans = mid;
else r = mid - 1;
}
return a[ans];
} signed main() {
#ifdef WIN64
freopen("1.in", "r", stdin);
#endif
std::cin >> n;
for(int i = 1; i <= n; ++i) std::cin >> a[i];
std::sort(a + 1, a + n + 1);
std::cin >> m;
while(m--) {
ll x; std::cin >> x;
ll t = find_min(x), t1 = find_max(x);
if(abs(t - x) > abs(t1 - x)) std::swap(t, t1);
printf("%lld\n", t);
}
}

C 救救企鹅

和gdoi2017d1t1很像,显然直接跑一遍kmp就行了,就是把输出改为标记,注意因为不能重复覆盖,所以要跳过一整段,注意这个时候中间这段也要更新next值。

#include <bits/stdc++.h>
using namespace std; #define N 1000010
char s[N], a[N], b[N];
int nxt[N], vis[N]; int main() {
scanf("%s%s%s", s + 1, a + 1, b + 1);
int n = strlen(s + 1);
int m = strlen(a + 1), k = strlen(b + 1);
for(int i = 2, j = 0; i <= m; ++i) {
while(j && a[j + 1] != a[i]) j = nxt[j];
if(a[j + 1] == a[i]) ++j;
nxt[i] = j;
}
for(int i = 1, j = 0; i <= n; ++i) {
while(j && a[j + 1] != s[i]) j = nxt[j];
if(a[j + 1] == s[i]) ++j;
if(j == m) {
vis[i - m + 1] = 1;
int lim = i + m - 2;
j = 0;
for(; i <= lim; ++i) {
while(j && a[j + 1] != s[i]) j = nxt[j];
if(a[j + 1] == s[i]) ++j;
}
--i;
}
}
for(int i = 1; i <= n; ++i) {
if(vis[i] == 1) {
i += m - 1;
for(int l = 1; l <= k; ++l) putchar(b[l]);
continue;
}
putchar(s[i]);
}
}

D 数糖纸

尺取法经典题。

瓶颈在离散(换成map,set也行)

map会被卡。

牛客评测机差评..一样的代码交一次70交第二次90...

因为被卡了所以就没ak了qaq。

map代码(大概在5070浮动,加了读优的话在7090浮动)

#include <bits/stdc++.h>
using namespace std; #define N 1000010
#define ll long long
int n, last[N];
ll a[N];
map<ll, int>v; int main() {
scanf("%d", &n);
for(int i = 1; i <= n; ++i) {
scanf("%lld", &a[i]);
if(v[a[i]]) {
last[i] = v[a[i]];
}
v[a[i]] = i;
}
int l = 1, ans = 1;
for(int r = 1; r <= n; ++r) {
while(l < r && last[r] >= l) ++l;
ans = max(r - l + 1, ans);
}
printf("%d\n", ans);
}

set代码

#include <bits/stdc++.h>
using namespace std; #define N 1000010
#define ll long long
int n;
int last[N], a[N];
set<int>s; int main() {
scanf("%d", &n);
int l = 1, ans = 0;
for(int i = 1; i <= n; ++i) {
scanf("%d", &a[i]);
while(s.count(a[i]) && l < i) s.erase(a[l++]);
s.insert(a[i]);
ans = max(ans, (int)s.size());
}
printf("%d\n", ans);
}

牛客OI周赛7-普及组 解题报告的更多相关文章

  1. 牛客OI周赛9-提高组题目记录

    牛客OI周赛9-提高组题目记录 昨天晚上做了这一套比赛,觉得题目质量挺高,而且有一些非常有趣而且非常清奇的脑回路在里边,于是记录在此. T1: 扫雷 题目链接 设 \(f_i\) 表示扫到第 \(i\ ...

  2. 牛客OI周赛8-提高组A-用水填坑

    牛客OI周赛8-提高组A-用水填坑 题目 链接: https://ac.nowcoder.com/acm/contest/403/A 来源:牛客网 时间限制:C/C++ 2秒,其他语言4秒 空间限制: ...

  3. 牛客OI周赛2-提高组

    A.游戏 链接:https://www.nowcoder.com/acm/contest/210/A来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 131072K,其他语 ...

  4. 牛客OI周赛11-普及组 B Game with numbers (数学,预处理真因子)

    链接:https://ac.nowcoder.com/acm/contest/942/B 来源:牛客网 Game with numbers 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C+ ...

  5. 牛客OI周赛7-提高组 A 小睿睿的等式

    链接:https://ac.nowcoder.com/acm/contest/371/A来源:牛客网 小睿睿在游戏开始时有n根火柴棒,他想知道能摆成形如“A+B=n”的等式且使用的火柴棒数也恰好等于n ...

  6. 牛客OI周赛7-提高组 B小睿睿的询问(ST打表)

    链接:https://ac.nowcoder.com/acm/contest/371/B来源:牛客网 小睿睿的n个妹纸排成一排,每个妹纸有一个颜值val[i].有m个询问,对于每一个询问,小睿睿想知道 ...

  7. 牛客OI周赛10-普及组-A眼花缭乱的街市-(加速+二分)

    https://ac.nowcoder.com/acm/contest/901/A 很简单的一道题,全场只有20+AC,卡时间.新学了cin加速语法和数组二分查找的函数调用. 知道有个读写挂,可以加速 ...

  8. 补比赛——牛客OI周赛9-普及组

    比赛地址 A 小Q想撸串 题目分析 普及T1水题惯例.字符串中找子串. Code #include<algorithm> #include<iostream> #include ...

  9. 牛客OI周赛8-普及组

    https://ac.nowcoder.com/acm/contest/543#question A. 代码: #include <bits/stdc++.h> using namespa ...

随机推荐

  1. 交替最小二乘ALS

    https://www.cnblogs.com/hxsyl/p/5032691.html http://www.cnblogs.com/skyEva/p/5570098.html 1. 基础回顾 矩阵 ...

  2. [博客迁移]探索Windows Azure 监控和自动伸缩系列1 - 连接中国区Azure

    最近准备基于Microsoft Azure Management Libraries 实现虚拟机的监控.主要的需求就是获取虚拟机内置的性能计数器数据,基于性能计数器实现后续的监控和自动伸缩. 作为这一 ...

  3. GridFS Example

    http://api.mongodb.com/python/current/examples/gridfs.html This example shows how to use gridfs to s ...

  4. 集合——顶层collection接口(单列集合)

    顶层接口的抽象方法为共性抽取的方法,即所有子类都有都可以用; 创建集合,泛型使用字符床类型String类型, 其中,new的对象,打印对象名应该是一个存储在栈内存中的地址值:这边打印出来是空即 [ ] ...

  5. 【Alpha版本】冲刺阶段——Day7

    [Alpha版本]冲刺阶段--Day7 阅读目录 今日进展 今日贡献量 贡献量汇总 TODOList 及项目燃尽图 [今日进展] 将项目源文件打成jar包,并运行测试 完成答辩ppt 项目运行情况 主 ...

  6. tomcat1章1

    package ex01.pyrmont; import java.net.Socket; import java.net.ServerSocket; import java.net.InetAddr ...

  7. Django 安装 创建项目 运行项目

    Django基础 框架,即framework,特指为解决一个开放性问题而设计的具有一定约束性的支撑结构,使用框架可以帮你快速开发特定的系统,简单地说,就是你用别人搭建好的舞台来做表演. 对于所有的We ...

  8. 51nod 1057 N的阶乘 (大数运算)

    输入N求N的阶乘的准确值.   Input 输入N(1 <= N <= 10000) Output 输出N的阶乘 Input示例 5 Output示例 120 压位: 每个数组元素存多位数 ...

  9. SSM的理解

    SSM(Spring+SpringMVC+MyBatis)框架集由Spring.SpringMVC.MyBatis三个开源框架整合而成,常作为数据源较简单的web项目的框架.其中spring是一个轻量 ...

  10. 关于mapreducer 读取hbase数据 存入mysql的实现过程

    mapreducer编程模型是一种八股文的代码逻辑,就以用户行为分析求流存率的作为例子 1.map端来说:必须继承hadoop规定好的mapper类:在读取hbase数据时,已经有现成的接口 Tabl ...