Day 1的题难度上来说不算太高,但是T2和T3还是有一定的思维量的。
一个比较好的开始。虽然AK的人只有几个。。
(懒得去翻result了。。忘了当时拿了多少分了
(哦,前两天我们机房是没有成绩的,我好像忘了这一点。
 
那么我们直奔主题吧。
 
T1:删除
文件名
del.cpp/c/pas
输入文件 输出文件 时间限制 空间限制
del.in del.out 1s 512MB
题目描述
现在,我的手上有 n 个数字,分别是 a1, a2, a3, ..., an
我现在需要删除其中的 k 个数字。当然我不希望随随便便删除,我希望删除 k个数字之后,剩下的 n − k 个数中有最多的不同的数。
输入格式
第一行两个正整数 n 和 k,含义如题目描述。
接下来一行,有 n 个非负整数,分别是 a1到 an
输出格式
一共一行,一个整数 ans,表示删除了 k 个数字后最多的不同的数的个数。
样例输入
4 1
1 3 1 2
样例输出
3
样例解释
如果删去第一个 1:
在[3,1,2]中有 3 个不同的数
如果删去 3:
在[1,1,2]中有 2 个不同的数
如果删去第二个 1:
在[1,3,2]中有 3 个不同的数
如果删去 2:
在[1,3,1]中有 1 个不同的数
数据范围
对于 30% 的数据,n ≤ 10,a ≤ 10。
对于 60% 的数据,n ≤ 100,a ≤ 100。
对于 80% 的数据,n ≤ 105,a ≤ 105
对于 100% 的数据,n ≤ 105,a ≤ 109
 
这道题算是比较基础的一道题了。当时我在考场上想到了一个自认为是正解的做法,但下午讲解时被告知是80分的伪正解做法。。
我太菜了.jpg
我当时想的是,开一个数组,统计每个数字出现的次数,既然我们要删除k个数字而且要保证删除后的数字是最多的,那很显然想到要先删除重复的。
统计一下有多少个重复的数字,将这个数与k比较。
如果k比这个数小或者等于这个数,那说明我们删除k个数对数字的种类没有任何影响。我们仅仅删除了重复的数字而已。那么答案就是数字的种数。
如果k比这个数字大,那说明我们即使全部删除所有的重复数字,也达不到k这个值,那只好再去删除不重复的数字,我们无需关心到底是删除了哪个数,而只需要统计出数字有多少种即可。
假设有m种数字,删除k个数,设x等于删除完所有重复数字后还需要删除多少数,那么根据上边的分析,答案应该是m-x.
 
100分做法:
善用排序。我们完全可以不用统计每个数字出现的次数,只需要读入之后sort(salt)一下,这样相同的数字会排在一起,我们就能统计出有多少相同的数字可供删除,以及数字的种类。
 
GTY哥哥的std:
 #include <cstdio>
#include <cstring>
#include <cmath>
#include <cstdlib>
#include <iostream>
#include <vector>
#include <set>
#include <map>
#include <algorithm>
using namespace std; const int max_n = 1e5 + ;
int n, k, a[max_n]; int main() {
freopen("del.in", "r", stdin);
freopen("del.out", "w", stdout); cin >> n >> k; for (int i = ; i <= n; i++)
cin >> a[i]; sort(a + , a + + n); int multi = ;
for (int i = ; i <= n; i++)
if (a[i] == a[i - ]) multi++;
if (k <= multi) cout << n - multi << endl;
else cout << n - multi - (k - multi) << endl;
}
 
 
T2:同花顺
题目描述
所谓同花顺,就是指一些扑克牌,它们花色相同,并且数字连续。
现在我手里有 n 张扑克牌,但它们可能并不能凑成同花顺。我现在想知道,最少更换其中的多少张牌,我能让这 n 张牌都凑成同花顺?
输入格式
第一行一个整数 n,表示扑克牌的张数。
接下来 n 行,每行两个整数 a 和 b 。其中 ai表示第 i 张牌的花色,bi表示第i 张牌的数字。
输出格式
一行一个整数,表示最少更换多少张牌可以达到目标。
样例输入 1
5
1 1
1 2
1 3
1 4
1 5
样例输出 1
0
样例输入 2
5
1 9
1 10
2 11
2 12
2 13
样例输出 2
2
数据范围
对于 30% 的数据,n ≤ 10。
对于 60% 的数据,n ≤ 105,1 ≤ a ≤ 105,1 ≤ b ≤ n。
对于 100% 的数据,n ≤ 105,1 ≤ ai, bi ≤ 109
 
当时在考场上只想到了暴力搜索。。。不过仔细一考虑,这题其实挺简单的。
数据量比较大,需要我们进行离散化,去除相同的牌。一个显然的贪心就是找到花色出现次数最多的花色,则其他的花色的牌一定要换掉。
做到这里,应该能拿60.
100分做法:我们枚举在已有的同花顺序列上的最后一张牌,去寻找可能的第一张牌。我们令last为当前牌作为同花顺序列的最后一张牌时,可能的第一张牌。如果当前牌的点数是a,last牌的点数是b,则必须要满足a-b+1≤n。
GTY哥哥的std:
 #include <cstdio>
#include <cstring>
#include <cmath>
#include <cstdlib>
#include <iostream>
#include <algorithm>
using namespace std; const int max_n = 1e5 + ; struct card {
int color, value;
bool operator < (const card &o) const {
return color < o.color || (color == o.color && value < o.value);
}
bool operator == (const card &o) const {
return color == o.color && value == o.value;
}
} a[max_n];
int n; int main() {
freopen("card.in", "r", stdin);
freopen("card.out", "w", stdout);
cin >> n;
for (int i = ; i <= n; i++) {
cin >> a[i].color >> a[i].value;
} sort(a + , a + + n);
int ori_n = n;
n = unique(a + , a + + n) - (a + ); int last_one = ;
int max_ans = ;
for (int i = ; i <= n; i++) {
if (i == || a[i].color != a[i - ].color)
last_one = i;
while (a[i].value - a[last_one].value + > ori_n)
last_one++;
max_ans = max(max_ans, i - last_one + );
} cout << ori_n - max_ans << endl;
}
 
T3:等式
题目描述
我有 n 个式子
对于每一个式子,要么是 x = x 的形式,要么是 x ≠ x 的形式。
现在我给出这 n 个式子,你要告诉我,这 n 个式子是否可能同时成立。
输入格式
每一个测试点有多组测试数据。
第一行有一个整数 T,表示测试数据的组数。
对于每一组测试数据,第一行包含一个正整数 n,表示式子的数目。
接下来 n 行,每行三个整数 i,j,e,描述一个式子。如果 e = 1,则这个式子为 x = x 。如果 e = 0,则这个式子是 x ≠ x 。
输出格式
对于每一个测试数据输出一行。如果存在一种方案,使得所有的式子都被满足,输出“YES”(不包含引号)。否则输出“NO”(不包含引号)。
样例输入 1
2
2
1 2 1
1 2 0
2
1 2 1
2 1 1
样例输出 1
NO
YES
6
样例输入 2
2
3
1 2 1
2 3 1
3 1 1
4
1 2 1
2 3 1
3 4 1
1 4 0
样例输出 2
YES
NO
数据范围
对于 20% 的数据,n ≤ 10。
对于 40% 的数据,n ≤ 100。
对于 70% 的数据,n ≤ 105,1 ≤ i, j ≤ 104
对于 100% 的数据,n ≤ 105,1 ≤ i, j ≤ 109 ,1 ≤ t ≤ 10。
 
这题其实就是NOI2015D1T1那个等价表达式。。
不过GTY哥哥为我们提供了一个算法,虽然只有70分但是听起来很有趣,读者不妨一试。
 
floodfill算法。将所有的等式关系建成一个图。然后我们循环每一个点,如果当前点还没有被访问过,则从这个点开始,dfs遍历所有和它有边相连的点,并标记。注意,标记是不一样的。从1开始遍历就标记为1,从2开始遍历就标记为2。然后我们检查所有的不等式。如果要求不等的两个点i和j标记相同,说明它们被要求“等于”,就输出NO。如果所有要求不等的两个点都不在一个联通块内,则输出YES。
 
正解应该是离散化+并查集,我在Day2内容整理里稍微说了一下。。
 
   GTY哥哥的std:
  

 #include <cstdio>
#include <cstring>
#include <cmath>
#include <cstdlib>
#include <iostream>
#include <algorithm>
using namespace std; const int max_n = 2e5 + ; struct data {
int x, y, e;
bool operator < (const data &o) const {
return e > o.e;
}
} a[max_n]; int fa[max_n];
int tmp[max_n], tot, n; int getfather(int x) {
if (fa[x] == x) return x;
return fa[x] = getfather(fa[x]);
} inline int getnum() {
int ans = ; char c; bool flag = false;
while (!isdigit(c = getchar()) && c != '-');
if (c == '-') flag = true; else ans = c - '';
while (isdigit(c = getchar())) ans = ans * + c - '';
return ans * (flag ? - : );
} int main() {
freopen("equ.in", "r", stdin);
freopen("equ.out", "w", stdout); int t = getnum();
while (t--) {
n = getnum();
tot = ;
for (int i = ; i <= n; i++) {
a[i].x = getnum();
a[i].y = getnum();
a[i].e = getnum();
tmp[++tot] = a[i].x;
tmp[++tot] = a[i].y;
} sort(a + , a + + n);
sort(tmp + , tmp + + tot);
tot = unique(tmp + , tmp + + tot) - (tmp + ); for (int i = ; i <= tot; i++) fa[i] = i; bool isok = true;
for (int i = ; i <= n; i++) {
a[i].x = lower_bound(tmp + , tmp + + tot, a[i].x) - tmp;
a[i].y = lower_bound(tmp + , tmp + + tot, a[i].y) - tmp;
if (a[i].e == ) fa[getfather(a[i].x)] = getfather(a[i].y);
else {
if (getfather(a[i].x) == getfather(a[i].y)) {
isok = false;
break;
}
}
} if (isok) cout << "YES" << endl;
else cout << "NO" << endl;
}
}

你问我为啥这些标程都不是我写的?

   源代码丢了……只能用一下天宇哥哥的std了。。。
 
 

夏令营提高班上午上机测试 Day 1 解题报告的更多相关文章

  1. 夏令营提高班上午上机测试 Day 2 解题报告

    那一天,日照一中夏令营数据结构提高班的同学们终于想起了,被Day2上午的三道题支配的恐惧……   是的..这一天的题有点难想.. 本来打算前天写这篇随笔,然而前天在机房和同学打luogu月赛…… 昨天 ...

  2. 夏令营提高班上午上机测试 Day 3 解题报告

    今天的题的确水.T3还是一道NOIP原题. 嘛,多刷点水题也不是什么坏事嘛. 说来也快,夏令营结束了整一星期了呢.大家也都回到了日常的暑假生活呢. 今天学业水平测试出成绩了...嗯结果还算满意呢,至少 ...

  3. 夏令营提高班上午上机测试 Day 4 解题报告

    我要是没记错的话,今天的题难度算挺适中的. *标程来自高天宇哥哥 T1:小G的字符串 题目描述 有一天,小 L 给小 G 出了这样一道题:生成一个长度为 n 的.全由小写英文字母构成的字符串,只能使用 ...

  4. nowcoder(牛客网)OI测试赛3 解题报告

    昨天因为胡搞了一会儿社团的事情,所以错过(逃过)了nowcoder的测试赛..... 以上,听说还是普及组难度qwq,而且还有很多大佬AK(然而我这么蒻肯定还是觉得有点难度的吧qwq) 不过我还是日常 ...

  5. 牛客OI赛制测试赛3 解题报告

    前话: 话说考试描述:普及难度. 于是想在这场比赛上涨点信心. 考出来的结果:Point:480     Rank:40 然而同机房的最好成绩是 510. 没考好啊!有点炸心态,D题一些细节没有注意, ...

  6. nowcoder(牛客网)提高组模拟赛第四场 解题报告

    T1 动态点分治 就是模拟..... 但是没有过!! 看了题解之后发现.... 坑点:有可能 \(x<=r\),但是

  7. nowcoder(牛客网)OI测试赛2 解题报告

    qwq听说是一场普及组难度的比赛,所以我就兴高采烈地过来了qwq 然后发现题目确实不难qwq.....但是因为蒟蒻我太蒻了,考的还是很差啦qwq orz那些AK的dalao们qwq 赛后闲来无事,弄一 ...

  8. nowcoder 提高组模拟赛 最长路 解题报告

    最长路 链接: https://www.nowcoder.com/acm/contest/178/A 来源:牛客网 题目描述 有一张 \(n\) 个点 \(m\) 条边的有向图,每条边上都带有一个字符 ...

  9. [jzoj 4668] [NOIP2016提高A组模拟7.19] 腐败 解题报告(质数分类+慢速乘)

    题目链接: http://172.16.0.132/senior/#main/show/4668 题目: 题解: 考虑把A数组里的每个元素分解质因数,对于每个质因数开一个vector存一下包含这个质因 ...

随机推荐

  1. os系统

    任务延时函数OSTimeDly 功能:调用该函数的任务将自己延时一段时间并执行一次任务调度,一旦规定的延时时间完成或有其它的任务通过调用OSTimeDlyResume()取消了延时,调用OSTimeD ...

  2. angular2 Http和websocket

    1. 注入HttpModule模块: 2. 注入http服务 map方法需要导入"rajx/Rx"组件,作用是针对流的处理.Json是将流转化为json格式.subscribe订阅 ...

  3. POJ 2387 Til the Cows Come Home(模板——Dijkstra算法)

    题目连接: http://poj.org/problem?id=2387 Description Bessie is out in the field and wants to get back to ...

  4. Yourphp系统发生错误

    今天早用YP更新缓存,弹出如下错误: 随之而来的是错误信息是: [php] view plain copy [14-12-03 10:48:12] E:\wwwweb\xmwszt360\Core\L ...

  5. php对数组进行分页

      3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 ...

  6. ios开发 第三天

    1.复合 对象可以引用其它对象,可以利用其它对象提供的特性. 通过包含作为实例变量的对象指针实现的. 2.OC是单一继承 3.继承-重构 4.类实例化对象时,self指向了对象的首地址. 类对象isa ...

  7. JVM核心之JVM运行和类加载全过程

    为什么研究类加载全过程? 有助于连接JVM运行过程 更深入了解java动态性(解热部署,动态加载),提高程序的灵活性 类加载机制 JVM把class文件加载到内存,并对数据进行校验.解析和初始化,最终 ...

  8. MVVM探索:从ViewModel关闭Window的最佳实践

    在WPF里使用MVVM开发的时候,似乎总是不可避免的会遇到这样一个问题:ViewModel在处理完业务之后需要关闭这个Window,这时候要怎么处理? 网上有很多解决方案:有的在ViewModel抛出 ...

  9. [转]怎么查看和修改 MySQL 的最大连接数?

    使用 MySQL 数据库的站点,当访问连接数过多时,就会出现 "Too many connections" 的错误.出现这种错误有两种情况,一种是网站访问量实在太大,服务器已经负担 ...

  10. Web前端学习(4):显示图片、url与文件路径

    本章主旨 介绍<img>标签及其基本属性:介绍URL和文件路径 在上一章中,我简单地介绍了HTML的一些基本标签及基本属性,例如,我们用<p>标签来标记文本段落,用<h1 ...