【洛谷 P8630】[蓝桥杯 2015 国 B] 密文搜索 题解(字符串+映射+排序)

[蓝桥杯 2015 国 B] 密文搜索

题目描述

福尔摩斯从 X 星收到一份资料,全部是小写字母组成。

他的助手提供了另一份资料:许多长度为 8 8 8 的密码列表。

福尔摩斯发现,这些密码是被打乱后隐藏在先前那份资料中的。

请你编写一个程序,从第一份资料中搜索可能隐藏密码的位置。要考虑密码的所有排列可能性。

输入格式

输入第一行:一个字符串 s s s,全部由小写字母组成,长度小于 1024 × 1024 1024 \times 1024 1024×1024

紧接着一行是一个整数 n , n, n, 表示以下有 n n n 行密码, 1 ≤ n ≤ 1000 1 \le n \le 1000 1n1000

紧接着是 n n n 行字符串,都是小写字母组成,长度都为 8 8 8

输出格式

一个整数,表示每行密码的所有排列在 s s s 中匹配次数的总和。

样例 #1

样例输入 #1

aaaabbbbaabbcccc
2
aaaabbbb
abcabccc

样例输出 #1

4

提示

第一个密码匹配了 3 3 3 次,第二个密码匹配了 1 1 1 次,一共 4 4 4 次。

时限 3 秒, 512M。蓝桥杯 2015 年第六届国赛


思路

首先,定义一些常量和变量。包括一个整数n,一个字符串s,一个字符串数组pw,和一个映射cnt。

然后,从输入流中读取字符串s和整数n。如果字符串s的长度小于8,那么直接输出0并返回。

接着,从输入流中读取n个密码,并将每个密码排序后存入映射cnt,键为排序后的密码,值为该密码出现的次数。

之后,遍历字符串s的所有长度为8的子串,将每个子串排序后查找在映射cnt中的出现次数,累加到答案ans中。

最后,输出答案ans。


AC代码

#include <algorithm>
#include <cmath>
#include <iostream>
#include <map>
#define AUTHOR "HEX9CF"
using namespace std;
using ll = long long;

const int N = 1e6 + 7;
const int INF = 0x3f3f3f3f;
const ll MOD = 1e9 + 7;

int n;
string s;
string pw[N];
map<string, int> cnt;

int main() {
	ios::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);

	cin >> s >> n;
	if (s.length() < 8) {
		cout << 0 << "\n";
		return 0;
	}
	for (int i = 1; i <= n; i++) {
		string pw;
		cin >> pw;
		sort(pw.begin(), pw.end());
		cnt[pw]++;
	}
	ll ans = 0;
	for (int i = 0; i + 8 <= s.length(); i++) {
		string ss = s.substr(i, 8);
		sort(ss.begin(), ss.end());
		ans += cnt[ss];
	}
	cout << ans << "\n";
	return 0;
}

最近更新

  1. TCP协议是安全的吗?

    2024-04-21 08:04:02       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-21 08:04:02       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-21 08:04:02       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-21 08:04:02       18 阅读

热门阅读

  1. 根据哈夫曼树求哈夫曼编码

    2024-04-21 08:04:02       15 阅读
  2. Edge的使用心得与深度探索

    2024-04-21 08:04:02       15 阅读
  3. CentOS 7 文件权限管理详解

    2024-04-21 08:04:02       13 阅读
  4. 软考高级架构师:软件需求管理例题解析

    2024-04-21 08:04:02       13 阅读
  5. 使用GPT帮忙修改论文

    2024-04-21 08:04:02       15 阅读
  6. Nginx基础(05)

    2024-04-21 08:04:02       16 阅读
  7. 【架构】Elasticsearch+Logstash+Kibana架构

    2024-04-21 08:04:02       16 阅读
  8. CentOS常见的命令

    2024-04-21 08:04:02       20 阅读
  9. Git 将一个项目同时推送到多个远程仓库

    2024-04-21 08:04:02       40 阅读