ACM-ICPC 2018 沈阳赛区网络预赛 I 题 Lattice's basics in digital electronics
原题链接:https://nanti.jisuanke.com/t/31450
附上队友代码:(感谢队友带飞)
#include <bits/stdc++.h>
using namespace std;
#define ll long long
#define FOR(i,a,b) for(int i=(a);i<=(b);++i)
#define DOR(i,a,b) for(int i=(a);i>=(b);--i)
const int maxN=2e5+5,inf=0x3f3f3f3f;
int N, M, K, T;
int g[maxN];
unordered_map<string,int> mp;
char S1[maxN * 4], S2[maxN * 4], S3[maxN * 4];
struct ND{
ND *lch, *rch;
char x;
};
char cg[20][5] = {"0000","0001","0010", "0011", "0100",
"0101", "0110", "0111", "1000", "1001", "1010",
"1011", "1100", "1101", "1110", "1111"};
bool judge(char *s, int st) {
int i = 0, one = 0;
while (i < 9 && s[st + i] != 0) {
if (s[st + i] == '1')
++one;
++i;
}
if (i < 9) return 0;
if (one & 1) return 1;
else return 0;
}
int main () {
#ifndef ONLINE_JUDGE
freopen("data.in", "r", stdin);
#endif
scanf("%d", &T);
while (T--) {
S1[0] = S2[0] = S3[0] = 0;
mp.clear();
scanf("%d%d", &M, &N);
int a;
char s[15];
FOR(i, 1, N) {
scanf("%d %s", &a, s);
mp[s] = a;
}
scanf("%s", S1);
for (int i = 0; S1[i] != 0; ++i) {
int cnt;
if (isdigit(S1[i])) cnt = S1[i] - '0';
else {
S1[i] = toupper(S1[i]);
cnt = S1[i] - 'A' + 10;
}
FOR(j, 0, 3) {
S2[i * 4 + j] = cg[cnt][j];
}
}
// puts(S1);
// puts(S2);
int L = strlen(S2), cnt = 0;
for (int i = 0; i < L; i += 9) {
bool ok = judge(S2, i);
if (ok) {
for (int j = i; j < i + 8; ++j)
S3[cnt++] = S2[j];
}
}
S3[cnt] = 0;
// cout << "cnt" << cnt << endl;
/*
for (int i = 0; i < cnt; ++i) {
if (i && i % 4 == 0) printf(" ");
printf("%c",S3[i]);
}
*/
//puts(S3);
string str = S3;
int L3 = str.length();
int idx = 0;
int all = 0;
while (idx < L3) {
for (int len = 1; len <= 10; ++len) {
if (L3 - idx + 1 < len) {
idx = L3;
break;
}
string subs = str.substr(idx, len);
if (mp.count(subs)) {
printf("%c", mp[subs]);
++all;
if (all == M) {
idx = L3;
break;
}
idx += subs.length();
break;
}
}
}
puts("");
}
return 0;
}
ACM-ICPC 2018 沈阳赛区网络预赛 I 题 Lattice's basics in digital electronics的更多相关文章
- 【ACM-ICPC 2018 沈阳赛区网络预赛 I】Lattice's basics in digital electronics
[链接] 我是链接,点我呀:) [题意] [题解] 每个单词的前缀都不同. 不能更明示了... 裸的字典树. 模拟一下.输出一下就ojbk了. [代码] #include <bits/stdc+ ...
- Fantastic Graph 2018 沈阳赛区网络预赛 F题
题意: 二分图 有k条边,我们去选择其中的几条 每选中一条那么此条边的u 和 v的度数就+1,最后使得所有点的度数都在[l, r]这个区间内 , 这就相当于 边流入1,流出1,最后使流量平衡 解析: ...
- ACM-ICPC 2018 沈阳赛区网络预赛 K题
题目链接: https://nanti.jisuanke.com/t/31452 AC代码(看到不好推的定理就先打表!!!!): #include<bits/stdc++.h> using ...
- Made In Heaven 2018 沈阳赛区网络预赛 D题
求第k短路 模板题 套模板即可 #include <iostream> #include <cstring> #include <cstdio> #include ...
- ACM-ICPC 2018 沈阳赛区网络预赛 K Supreme Number(规律)
https://nanti.jisuanke.com/t/31452 题意 给出一个n (2 ≤ N ≤ 10100 ),找到最接近且小于n的一个数,这个数需要满足每位上的数字构成的集合的每个非空子集 ...
- ACM-ICPC 2018 沈阳赛区网络预赛-K:Supreme Number
Supreme Number A prime number (or a prime) is a natural number greater than 11 that cannot be formed ...
- ACM-ICPC 2018 沈阳赛区网络预赛-D:Made In Heaven(K短路+A*模板)
Made In Heaven One day in the jail, F·F invites Jolyne Kujo (JOJO in brief) to play tennis with her. ...
- 图上两点之间的第k最短路径的长度 ACM-ICPC 2018 沈阳赛区网络预赛 D. Made In Heaven
131072K One day in the jail, F·F invites Jolyne Kujo (JOJO in brief) to play tennis with her. Howe ...
- ACM-ICPC 2018 沈阳赛区网络预赛 J树分块
J. Ka Chang Given a rooted tree ( the root is node 11 ) of NN nodes. Initially, each node has zero p ...
随机推荐
- 并不对劲的2-SAT
说明 板板题链接 这个人讲得很清楚 WAWAWAWA 建的边"不完整",比如当限制是"x为1时y一定为1"时,连x->y的边时,忘记连y'->x'的 ...
- Codeforces 1238F. The Maximum Subtree
传送门 考虑构造一些区间使得树尽可能的 "大" 发现这棵树最多就是一条链加上链上出去的其他边连接的点 构造的区间大概长这样(图比较丑请谅解..$qwq$,图中每一个 "└ ...
- Java EE javax.servlet ServletContainerInitializer接口
ServletContainerInitializer接口 public interface ServletContainerInitializer 一.介绍 该接口,允许在 web 应用程序的启动阶 ...
- IntelliJ IDEA Spring boot devtools 实现热部署
一.spring-boot-devtools是一个为开发者服务的一个模块,其中最重要的功能就是自动部署新代码. 二.原理 使用了两个ClassLoader,一个ClassLoader用来加载那些不会变 ...
- C# WPF 数据绑定
后台通知: public event PropertyChangedEventHandler PropertyChanged; protected void OnPropertyChanged(str ...
- Linux服务器不关机新增硬盘的方法
在开机状态下,插入磁盘之后,执行如下命令: ls /sys/class/scsi_host/host0 host1 host2 echo "- - -" > /sys/cla ...
- 【zhifu】web开发中的支付宝支付和微信支付
一.支付类型: 支付宝支付: 支付宝app内的网页支付: app外(即普通浏览器)网页支付: 微信支付: 微信app内的支付(在这里叫公众号支付) app外的支付(微信H5支付): 微信公众号的支付宝 ...
- BZOJ4241历史研究题解--回滚莫队
题目链接 https://www.lydsy.com/JudgeOnline/problem.php?id=4241 分析 这题就是求区间权值乘以权值出现次数的最大值,一看莫队法块可搞,但仔细想想,莫 ...
- 仍然有人在叫喊C语言已经过时了
现在,仍然有人在叫喊C语言已经过时了.还有什么值得学习的?看看现在使用Python.PHP和其他语言有多简单.谁去学旧的C语言?是真的吗?作者下载了这两种语言的底层源代码.由于空间的限制,它没有分析框 ...
- array数据处理
之前写过map,forEach,现在用到every和some,记录一下当作学习笔记,方便以后翻阅. forEach是没有返回值的,对原数组进行修改: // forEach没有返回值,只针对每个元素调用 ...