ACM学习历程—2016"百度之星" - 资格赛(Astar Round1)
http://bestcoder.hdu.edu.cn/contests/contest_show.php?cid=690
A题:
给定字符串,求任意区间的Hash值。
根据题目给定的Hash方式,属于乘法类型,那么就可以预处理出所有的乘法前缀,然后利用逆元,就可以得到任意区间的Hash值。
不过在这题上跪了好久,最后讨论版的一位大神给出了一个很叼的隐含条件:“同志们,当a, b超范围的时候,输出上一次询问的答案,亲测可行。。。太坑了。。。”
代码:
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <queue>
#include <map>
#include <set>
#include <string>
#include <vector>
#define MOD 9973 using namespace std; const int maxN = ;
int q, len, ans, inv[], s[maxN];
char str[maxN]; void init()
{
//***预处理所有i在质数MOD下的逆元
inv[] = ;
for (int i = ; i < ; i++)
inv[i] = inv[MOD%i]*(MOD-MOD/i) % MOD;
} void input()
{
scanf("%s", str);
len = strlen(str);
for (int i = ; i < len; ++i)
{
if (i == ) s[i] = (str[i]-+MOD)%MOD;
else s[i] = s[i-]*(str[i]-+MOD)%MOD;
}
} bool judge(int lt, int rt)
{
if (lt > rt) return false;
if (lt < || lt > len) return false;
if (rt < || rt > len) return false;
return true;
} inline int getHash(int from, int to)
{
return (from == ? s[to] : s[to]*inv[s[from-]]%MOD);
} void work()
{
int lt, rt;
for (int i = ; i < q; ++i)
{
scanf("%d%d", <, &rt);
if (judge(lt, rt))
ans = getHash(lt-, rt-);
printf("%d\n", ans);
}
} int main()
{
//freopen("test.in", "r", stdin);
//freopen("test.out", "w", stdout);
init();
while (scanf("%d", &q) != EOF)
{
input();
work();
}
return ;
}
B题:
一个递推,如果有n个1,那么要么前两个1结合,要么不结合,那么p(n) = p(n-1)+p(n-2)。然后Java大数直接打表。
代码:
import java.math.BigInteger;
import java.util.Scanner; public class Main
{
BigInteger p[] = new BigInteger[205]; void init()
{
p[1] = new BigInteger("1");
p[2] = new BigInteger("2");
for (int i = 3; i < 205; ++i)
p[i] = p[i-1].add(p[i-2]);
} public static void main(String[] args)
{
Scanner input = new Scanner(System.in);
Main ans = new Main();
int n = 0;
ans.init();
while (input.hasNext())
{
n = input.nextInt();
System.out.println(ans.p[n]);
}
}
}
C题:
一道字符串前缀问题。
有三种操作,插入一个单词,删除给定前缀的所有单词,查询是否存在给定前缀的单词。
用字典树搞,插入的时候,给路径上所有结点的vis加1。
删除的时候,删除前缀后面的所有子树,并将路径上所有结点的vis值,减去最末结点的vis值。
查询时,一旦路径上有一个vis值为0,就查询失败。
代码:
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <queue>
#include <map>
#include <set>
#include <string>
#include <vector> using namespace std; struct Trie
{
int vis;
int next[];
}tree[]; int q, top; void build()
{
top = ;
for (int i = ; i < ; ++i) tree[].next[i] = -;
tree[].vis = ;
} int createNode()
{
top++;
for (int i = ; i < ; ++i) tree[top].next[i] = -;
tree[top].vis = ;
return top;
} void add(char str[])
{
int len = strlen(str), k, now = ;
for (int i = ; i < len; ++i)
{
k = str[i]-'a';
if (tree[now].next[k] == -) tree[now].next[k] = createNode();
now = tree[now].next[k];
tree[now].vis++;
}
} void del(char str[])
{
int len = strlen(str), k, now = , cnt;
for (int i = ; i < len; ++i)
{
k = str[i]-'a';
if (tree[now].next[k] == -) return;
now = tree[now].next[k];
}
for (int i = ; i < ; ++i) tree[now].next[i] = -;
cnt = tree[now].vis;
now = ;
for (int i = ; i < len; ++i)
{
k = str[i]-'a';
now = tree[now].next[k];
tree[now].vis -= cnt;
}
} bool get(char str[])
{
int len = strlen(str), k, now = ;
for (int i = ; i < len; ++i)
{
k = str[i]-'a';
if (tree[now].next[k] == -) return false;
now = tree[now].next[k];
if (!tree[now].vis) return false;
}
return true;
} void work()
{
build();
char op[], str[];
for (int i = ; i < q; ++i)
{
scanf("%s%s", op, str);
switch (op[])
{
case 'i':
add(str);
break;
case 'd':
del(str);
break;
case 's':
if (get(str)) printf("Yes\n");
else printf("No\n");
break;
}
}
} int main()
{
//freopen("test.in", "r", stdin);
//freopen("test.out", "w", stdout);
while (scanf("%d", &q) != EOF)
work();
return ;
}
D题:
这题直接排序+map能过。没试字典树。
代码:
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <queue>
#include <map>
#include <set>
#include <string>
#include <vector> using namespace std; int main()
{
//freopen("test.in", "r", stdin);
//freopen("test.out", "w", stdout);
int n;
char str[];
while (scanf("%d", &n) != EOF)
{
map<string, int> s;
for (int i = ; i < n; ++i)
{
scanf("%s", str);
sort(str, str+strlen(str));
printf("%d\n", s[str]++);
}
}
return ;
}
ACM学习历程—2016"百度之星" - 资格赛(Astar Round1)的更多相关文章
- 2016百度之星 资格赛ABCDE
看题:http://bestcoder.hdu.edu.cn/contests/contest_show.php?cid=690 交题:http://acm.hdu.edu.cn/search.php ...
- HDU 5688:2016"百度之星" - 资格赛 Problem D
原文链接:https://www.dreamwings.cn/hdu5688/2650.html Problem D Time Limit: 2000/1000 MS (Java/Others) ...
- HDU 5686:2016"百度之星" - 资格赛 Problem B
原文链接:https://www.dreamwings.cn/hdu5686/2645.html Problem B Time Limit: 2000/1000 MS (Java/Others) ...
- HDU 5685:2016"百度之星" - 资格赛 Problem A
原文链接:https://www.dreamwings.cn/hdu5685/2637.html Problem A Time Limit: 2000/1000 MS (Java/Others) ...
- 2016"百度之星" - 资格赛(Astar Round1)D
Problem Description 度熊所居住的 D 国,是一个完全尊重人权的国度.以至于这个国家的所有人命名自己的名字都非常奇怪.一个人的名字由若干个字符组成,同样的,这些字符的全排列的结果中的 ...
- 2016百度之星资格赛 Round1(2,3,4题)
Problem B Accepts: 2515 Submissions: 9216 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536 ...
- 2016"百度之星" - 资格赛(Astar Round1)
逆元 1001 Problem A 求前缀哈希和逆元 #include <bits/stdc++.h> typedef long long ll; const int MOD = 9973 ...
- 2016"百度之星"-资格赛
//本题要求:(Ar*A2...An)%p,亦即[(A1*A2*...An)/(A1*A2*...Ar-1)]%p,由于A1*A2...An乘积过大,无法求得相除所得的结果 //我们需要用到乘法逆元( ...
- 2016"百度之星" - 资格赛(Astar Round1) 1004
思路:题目很简单,直接用map记录每个字符串的个数就可以了.记得对每个字符串先sort(). AC代码: #include <cstdio> #include <stdlib.h&g ...
随机推荐
- windows安装mysql教程2017最新
1.首先在mysql官网下载最新版mysql, 附上链接点击打开链接,根据你的系统型号选择对应的包下载,大约300多兆,版本号为5.7.19 下载完之后,解压缩,是一个标准的mysql文件 2.第二步 ...
- bfc (收集的)
一些基本概念 viewport: 展现网页的媒体,比如窗口或者某个区域,它的大小是有限制的,为了不被平台术语所束缚,我们给他起名viewport,中文意思就是视口. canvas: 而我们在渲染网页的 ...
- $Java-json系列(二):用JSONObject解析和处理json数据
本文中主要介绍JSONObject处理json数据时候的一些常用场景和方法. (一)jar包下载 所需jar包打包下载百度网盘地址:https://pan.baidu.com/s/1c27Uyre ( ...
- php任务管理器 —— Jobby
通过一个主crontab任务去维护别的任务 自定义的计划任务完全由PHP编写 任务的执行计划时间表设置与crontab的时间表设置语法一致 在指定的时间内只会运行一个任务 邮件告警异常退出任务 在ro ...
- 【CodeChef】Turbo Sort
题目链接:Turbo Sort 用java自带O(NlogN)的排序就可以,java要特别注意输入输出.输入用BufferedReader,输出用printWriter.printWriter的速度比 ...
- 移动端tap或touch类型事件的点透问题认识
1.什么是点透? 举例说明:下图B元素是黄色方块,B元素中包含了C元素,C元素是一个a链接,本身自带click事件按,然后又一个半透明的粉色元素A遮盖在B元素上(看图中A元素是覆盖在B元素上的,不然B ...
- js 工厂模式简要介绍
什么是工厂模式?就好比一个工厂,能造汽车.飞机...,通过对外接口,由顾客决定,来定制哪一款产品. 在js内表现为,一个工厂函数/对象,包含汽车.飞机等子类,提供对外接口,根据参数返回不同子类的实例 ...
- 【转载】如何简单地理解Python中的if __name__ == '__main__'
原帖:https://blog.csdn.net/yjk13703623757/article/details/77918633 通俗的理解__name__ == '__main__':假如你叫小明. ...
- 安装配置Apollo-Prota web中心平台
首先要求2g以上内存哈,JDK1.8 搭建数据库 创建表 apollo-build-scripts-master 整个阿波罗环境包 使用一个命令启动整个阿波罗服务环境 创建两个数据库 分别为:apol ...
- asp.net web api history and how does it work?
https://blogs.msdn.microsoft.com/zxue/2012/11/07/what-is-asp-net-web-api-and-how-does-it-work/ https ...