20240113-确定两个字符串是否接近

2024-01-14 15:52

本文主要是介绍20240113-确定两个字符串是否接近,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目要求

如果可以使用以下操作从另一个字符串获得一个字符串,则认为两个字符串是接近的:

  • 操作1:交换任意两个现有字符。 例如,abcde -> aecdb
  • 操作2:将每个出现的一个现有字符转换为另一个现有字符,并对另一个字符执行相同操作。 例如,aacabb -> bbcbaa(所有a都变成b,所有b都变成a)

您可以根据需要多次对任一字符串使用这些操作。 给定两个字符串,word1 和 word2,如果 word1 和 word2 接近,则返回 true,否则返回 false。

Example 1:

Input: word1 = "abc", word2 = "bca"
Output: true
Explanation: You can attain word2 from word1 in 2 operations.
Apply Operation 1: "abc" -> "acb"
Apply Operation 1: "acb" -> "bca"

Example 2:

Input: word1 = "a", word2 = "aa"
Output: false
Explanation: It is impossible to attain word2 from word1, or vice versa, in any number of operations.

Example 3:

Input: word1 = "cabbba", word2 = "abbccc"
Output: true
Explanation: You can attain word2 from word1 in 3 operations.
Apply Operation 1: "cabbba" -> "caabbb"
Apply Operation 2: "caabbb" -> "baaccc"Apply Operation 2: "baaccc" -> "abbccc"

思路

两个字符串相似的定义是“通过无限的操作能够互相得到”,因此我们似乎并不需要记住字母的顺序,只需要记住字母出现的次数即可。用到哈希表

  • 操作1:交换任意两个现有字符。 例如,abcde -> aecdb

很明显操作1中的操作并不改变字母的数量,但是可以1对1操作字母顺序。因此只要两个字符串每个字母出现的数量一致,都可以通过操作1互相转换。

  • 操作2:将每个出现的一个现有字符转换为另一个现有字符,并对另一个字符执行相同操作。 例如,aacabb -> bbcbaa(所有a都变成b,所有b都变成a)

操作2,交换不同字母的个数,也就是说我们甚至不需要准确的记录每个对应每个字母出现的次数,只要记录出现次数的list能对应上就可以。(但是统计个数也需要用哈希表来完成)

另外在获得map1和map2之后还需要判断一下二者的键是否都匹配,因为不存在的字母之间是无法互相转换的。

代码

class Solution {
public:bool closeStrings(string word1, string word2) {map<char, int> map1, map2;if (word1.size() != word2.size()) {return false;}for (int i = 0; i < word1.size(); ++i) {map1[word1[i]] += 1;map2[word2[i]] += 1;}for (auto &p : map1) {if (map2.find(p.first) == map2.end()) return false;}for (auto &p : map2) {if (map1.find(p.first) == map1.end()) return false;}vector<int> values1, values2;for (auto &p : map1) values1.push_back(p.second);for (auto &p : map2) values2.push_back(p.second);sort(values1.begin(), values1.end());sort(values2.begin(), values2.end());return values1 == values2;}
};

时间复杂度

  • 映射字符: O(N),其中 N 是字符串的长度。

  • 检查字符是否存在: O(N),假设映射操作为 O(log N),且最多有 N 个唯一字符。

  • 排序频率: O(N log N),因为频率排序最差也要对 N 个元素进行排序。

  • 总体时间复杂度 O(N log N),主要是排序步骤。

空间复杂度

  • 频率计数映射: O(N),用于存储字符频率。
  • 频率向量: O(N),用于存储频率的两个向量。
  • 整体空间复杂度:O(N) O(N),因为所用空间与唯一字符数成正比,最多为 N。

这篇关于20240113-确定两个字符串是否接近的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/605702

相关文章

Codeforces Round #113 (Div. 2) B 判断多边形是否在凸包内

题目点击打开链接 凸多边形A, 多边形B, 判断B是否严格在A内。  注意AB有重点 。  将A,B上的点合在一起求凸包,如果凸包上的点是B的某个点,则B肯定不在A内。 或者说B上的某点在凸包的边上则也说明B不严格在A里面。 这个处理有个巧妙的方法,只需在求凸包的时候, <=  改成< 也就是说凸包一条边上的所有点都重复点都记录在凸包里面了。 另外不能去重点。 int

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

easyui同时验证账户格式和ajax是否存在

accountName: {validator: function (value, param) {if (!/^[a-zA-Z][a-zA-Z0-9_]{3,15}$/i.test(value)) {$.fn.validatebox.defaults.rules.accountName.message = '账户名称不合法(字母开头,允许4-16字节,允许字母数字下划线)';return fal

【408DS算法题】039进阶-判断图中路径是否存在

Index 题目分析实现总结 题目 对于给定的图G,设计函数实现判断G中是否含有从start结点到stop结点的路径。 分析实现 对于图的路径的存在性判断,有两种做法:(本文的实现均基于邻接矩阵存储方式的图) 1.图的BFS BFS的思路相对比较直观——从起始结点出发进行层次遍历,遍历过程中遇到结点i就表示存在路径start->i,故只需判断每个结点i是否就是stop

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数

linux 判断某个命令是否安装

linux 判断某个命令是否安装 if ! [ -x "$(command -v git)" ]; thenecho 'Error: git is not installed.' >&2exit 1fi

C和指针:字符串

字符串、字符和字节 字符串基础 字符串就是一串零个或多个字符,并且以一个位模式为全0的NUL字节结尾。 字符串长度就是字符串中字符数。 size_t strlen( char const *string ); string为指针常量(const修饰string),指向的string是常量不能修改。size_t是无符号数,定义在stddef.h。 #include <stddef.h>

PHP字符串全排列

方法一: $str = 'abc';$a =str_split($str);perm($a, 0, count($a)-1);function perm(&$ar, $k, $m) {if($k == $m){ echo join('',$ar), PHP_EOL;}else {for($i=$k; $i<=$m; $i++) {swap($ar[$k], $ar[$i]);perm($ar

PHP7扩展开发之字符串处理

前言 这次,我们来看看字符串在PHP扩展里面如何处理。 示例代码如下: <?phpfunction str_concat($prefix, $string) {$len = strlen($prefix);$substr = substr($string, 0, $len);if ($substr != $prefix) {return $prefix." ".$string;} else