题解 Luogu P3370
讲讲这题的几种做法:
暴力匹配法
rt,暴力匹配,即把字符串存起来一位一位判相等
时间复杂度$ O(n^2·m) $
再看看数据范围
\(n\le10^5,m\le10^3\)
当场爆炸。当然有暴力分
代码(20pts):
#include <bits/stdc++.h>
using namespace std;
char c[100001][1001];
bool pd(int x, int y)
{
int l1 = strlen(c[x]), l2 = strlen(c[y]);
if(l1 != l2) return 0;
for(int i = 0; i < l1; i++)
{
if(c[x][i] != c[y][i]) return 0;
}
return 1;
}
int main()
{
int n;
cin >> n;
int ans = n;
for(int i = 1; i <= n; i++)
{
cin >> c[i];
for(int j = 1; j < i; j++)
{
if(pd(i, j)) ans--;
}
}
cout << ans;
return 0;
}

好漂亮呀
不要问我为什么WA了,我也没想调
string法
比较正常的方法
思路就是把所有串存下来,用string自带的运算符(大于等于小于)进行字典序排序
然后按照字典序判断是否重复即可
时间复杂度嘛
\(O(n·logn)\)的,可以卡过
代码(100pts):
#include <bits/stdc++.h>
using namespace std;
string s[10001];
int main()
{
int n;
cin >> n;
for(int i = 1; i <= n; i++)
{
cin >> s[i];
}
sort(s + 1, s + n + 1);//因为string自带大于和小于所以不用cmp
int ans = n;
for(int i = 1; i < n; i++)
{
if(s[i] == s[i + 1]) ans--;
//若两个字符串相同则他们的字典序一定是相邻的
}
cout << ans;
return 0;
}
C++STL法
我们当然可以用万能的STL做啦~
先来思考:我们判断一个数字是否重复是什么方法呢?
当然是bool used[1001] 啦
而这题要求判断的是字符串怎么办
把数组下标弄成string类型呗
请出主角:map
简单来讲,我们在定义数组时,只能确定数组中数的类型(比如char、bool、int、long long等等),而下标类型是固定的,即整数型
然而map可以确定这两个类型,也就是说,我们甚至可以把字符串作为下标,数字作为基本类型,来一个“反数组”(别问我反数组是啥,字面意思)
(那是不是要写成\(a_{interesting} = 3\)了)
那么结合上上上上上上上句话,这题就可做啦!
时间复杂度不明 反正能过就是了
代码(100pts):
#include <bits/stdc++.h>
using namespace std;
map < string , bool > m;//定义一个以string类型为下标的bool数组
string s;
int main()
{
int n;
cin >> n;
int ans = n;
for(int i = 1; i <= n; i++)
{
cin >> s;
if(m[s]) ans--;
else m[s] = 1;
}
cout << ans;
return 0;
}
比暴力短
HASH法
不要问为什么是最后,你见过哪个游戏让你一开始就打BOSS的?
这个和C++STL法有异曲同工之妙 说反了吧
既然字符串当不了下标,我们就把字符串转成数字嘛。
具体请看那个有几百个赞的dalao的题解吧(orz@_皎月半洒花%%%%%%)
代码(单hash,100pts):
#include <bits/stdc++.h>
#define ull unsigned long long
using namespace std;
ull base = 131;
ull a[100001];
char c[10001];
ull hashe(char s[])
{
int l = strlen(s);
ull ans = 0;
for(int i = 0; i < l; i++)
{
ans = (ans * base + (ull)(s[i])) % 200408020617;
}
return ans;
}
int main()
{
int n;
cin >> n;
for(int i = 1; i <= n; i++)
{
cin >> c;
a[i] = hashe(c);
}
sort(a + 1, a + n + 1);
ull ans = 1;
for(int i = 1; i < n; i++)
{
if(a[i] != a[i + 1]) ans++;
}
cout << ans;
return 0;
}
注:模数只写阳历生日太短会被卡?那就把 女朋友的 阴历生日加在后面鸭
题解 Luogu P3370的更多相关文章
- [题解] Luogu P5446 [THUPC2018]绿绿和串串
[题解] Luogu P5446 [THUPC2018]绿绿和串串 ·题目大意 定义一个翻转操作\(f(S_n)\),表示对于一个字符串\(S_n\), 有\(f(S)= \{S_1,S_2,..., ...
- 题解 Luogu P2499: [SDOI2012]象棋
关于这道题, 我们可以发现移动顺序不会改变答案, 具体来说, 我们有以下引理成立: 对于一个移动过程中的任意一个移动, 若其到达的位置上有一个棋子, 则该方案要么不能将所有棋子移动到最终位置, 要么可 ...
- 题解 luogu P1144 【最短路计数】
本蒟蒻也来发一次题解第一篇请见谅 这个题有几个要点 1.无向无权图,建图的时候别忘记建来回的有向边[因此WA掉1次 2.无权嘛,那么边长建成1就好了2333333 3.最短路采用迪杰斯特拉(别忘用堆优 ...
- 题解 Luogu P1110 【[ZJOI2007]报表统计】
感谢 @cmy962085349 提供的hack数据,已经改对了. 先声明,我好像是题解里写双$fhq$ $treap$里唯一能过的...(最后两个点啊) 思路:首先看题目,$MIN_GAP_SORT ...
- 题解 Luogu P3623 [APIO2008]免费道路
[APIO2008]免费道路 题目描述 新亚(New Asia)王国有 N 个村庄,由 M 条道路连接.其中一些道路是鹅卵石路,而其它道路是水泥路.保持道路免费运行需要一大笔费用,并且看上去 王国不可 ...
- Luogu P3370 【模板】字符串哈希
方法很多,hash,双hash(个人想到一种三hash),挂链,还有STL: map 乱搞 CODE #include<iostream> #include<map> #inc ...
- [题解]luogu P4116 Qtree3
终于来到了Qtree3, 其实这是Qtree系列中最简单的一道题,并不需要线段树, 只要树链剖分的一点思想就吼了. 对于树链剖分剖出来的每一根重链,在重链上维护一个Set就好了, 每一个Set里存的都 ...
- 题解 Luogu P3959 【宝藏】
来一篇不那么慢的状压??? 话说这题根本没有紫题难度吧,数据还那么水 我是不会告诉你我被hack了 一看数据规模,n≤12,果断状压. 然后起点要枚举,就设dp状态: f[i][j]=以i为起点到j状 ...
- 题解 Luogu P1099 【树网的核】
这题是真的水啊... ------------ 昨天模拟赛考了这题,很多人都是O($n^3$)水过,但我认为,要做就做的足够好(其实是我根本没想到O($n^3$)的做法),然后就开始想O(n)的解法. ...
随机推荐
- 工具之cut
转自http://www.cnblogs.com/dong008259/archive/2011/12/09/2282679.html cut:正如其名就是“剪”,和sed一样,一行为单位,对数据进行 ...
- windows RabbitMQ安装与配置
windows RabbitMQ安装与配置 1.安装Erlang 下载地址: http://www.erlang.org/downloads 注意: 右键以管理员身份进行安装,否则将导致后续无法启动 ...
- SVM(1)模式识别课堂笔记
引言:当两类样本线性可分时,针对我们之前学习的感知机而言,存在多个超平面能将数据分开,这里要讨论什么样的分类面最好的问题.为此,我们形式化的定义了最优分类超平面,他有两点特征:1.能将训练样本没有错误 ...
- convertto-securestring结果 使用python解密
根据微软帮助文档,convertto-securestring有两种加密模式.如果在指定密码的情况下,则使用aes加密,否则使用windows dpapi加密.而且aes加密也没有指明iv值与加密模式 ...
- HanLP《自然语言处理入门》笔记--6.条件随机场与序列标注
笔记转载于GitHub项目:https://github.com/NLP-LOVE/Introduction-NLP 6. 条件随机场与序列标注 本章介绍一种新的序列标注模型条件随机场.这种模型与感知 ...
- openstack启动云主机的流程
看一下openstack启动云主机的流程图 通过上图分析可以知道: 1. 用户使用Dashboard或者CLI 把认证信息通过REST请求发送给keystone进行认证.2. Keystone校验用户 ...
- Java.work6 stasic、this、包总结作业20194651
题目一: 编写一个类Computer,类中含有一个求n的阶乘的方法.将该类打包,并在另一包中德Java文件App.java中引入包,在主类中定义Computer类的对象,调用求n的阶乘的方法(n值由参 ...
- Codeforces gym101755H Safe Path(bfs)
题意: 给以一个网格图,有起点终点和一些怪兽,可以上下左右走,不能走到距离怪兽曼哈顿距离为d以内的地方,问到终点最短路径 n*m<=2e5,d<=2e5 思路: 因为n*m的范围,不能直接 ...
- Unity酱~ 卡通渲染技术分析(一)
前面的话 unitychan是日本unity官方团队提供的一个Demo,里面有很好的卡通渲染效果,值得参考学习 上图是我整理出来的shader结构,可以看到Unity娘被拆分成了很多个小的部件,我想主 ...
- docker pull 时报错Create more free space in thin pool or use dm.min_free_space option to change behavior
docker pull 时报错: failed to register layer: devmapper: Thin Pool has 107394 free data blocks which is ...