给定一个字符串,其中字母的表示方式被打乱的数字

给定一个字符串,其中字母的表示方式被打乱的数字

在今天的文章中,我们将深入探讨与C++中字符串操作相关的一个独特问题。这个问题是“在给定字符串中,字母表达式被打乱的数字。” 这个问题可以作为一个很好的练习,来提高你在C++中的字符串操作和数据结构技能。

问题陈述

给定一个字符串,任务是识别其中字母表达方式被打乱的数字。例如,如果输入字符串是”oentow”,它有一个数字2(t, w, o)和数字1(o, n, e)的字母表达方式被打乱。

C++解决方案方法

为了解决这个问题,我们将在C++中使用哈希表或无序映射来存储字符串中字母的频率。然后,我们将将此频率映射与每个数字的字母表示的预定义映射进行比较。如果一个数字的表示可以从输入字符串中形成,我们将输出该数字。

Example

的中文翻译为:

示例

这是解决问题的C++代码 −

#include #include #include // Array of digit representationsstd::string digitRepresentations[10] = {"zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine"};std::unordered_map generateFrequencyMap(std::string str) {   std::unordered_map freqMap;   for (char c : str) {      freqMap[c]++;   }   return freqMap;}std::vector findJumbledDigits(std::string str) {   std::unordered_map strFreqMap = generateFrequencyMap(str);   std::vector digits;      for (int i = 0; i < 10; i++) {      std::unordered_map digitFreqMap = generateFrequencyMap(digitRepresentations[i]);      bool canFormDigit = true;         for (auto pair : digitFreqMap) {         if (strFreqMap[pair.first] < pair.second) {               canFormDigit = false;               break;         }      }         if (canFormDigit) {         digits.push_back(i);      }   }   return digits;}int main() {   std::string input = "oentow";   std::vector digits = findJumbledDigits(input);      std::cout << "The jumbled digits in the string are: ";   for (int digit : digits) {      std::cout << digit << " ";   }   return 0;}

输出

The jumbled digits in the string are: 1 2 

Explanation with a Test Case

的翻译为:

使用测试案例解释

让我们考虑字符串”oentow”。

当这个字符串被传递给findJumbledDigits函数时,它首先为字符串生成一个频率映射:{‘o’: 2, ‘e’: 1, ‘n’: 1, ‘t’: 1, ‘w’: 1}。

然后,对于从0到9的每个数字,它生成数字的字母表示的频率映射,并检查该映射是否可以从字符串的频率映射中形成。

数字1的表示形式“one”具有频率映射 {‘o’: 1, ‘n’: 1, ‘e’: 1},而数字2的表示形式“two”具有频率映射 {‘t’: 1, ‘w’: 1, ‘o’: 1}。

这两个可以由字符串的频率映射生成,所以我们将这些数字添加到结果中。

最后,它输出结果:”The jumbled digits in the string are: 1 2″。

结论

这个问题展示了我们如何使用频率映射来解决C++中的复杂字符串操作问题。这是一个很好的问题,可以练习你的字符串和数据结构处理技巧。继续练习这样的问题,提升你的C++编码能力。

以上就是给定一个字符串,其中字母的表示方式被打乱的数字的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1444955.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 22:02:53
下一篇 2025年12月17日 22:03:04

相关推荐

  • 使用C++程序将字符串中的所有辅音替换为最近的元音

    该方法旨在用字母表中最接近的元音(也称为小写拉丁字母)替换一串辅音。如果两个元音同样接近,我们可以用这些字母中的第一个元音来替换它们。 让我们来看一些输入场景 – 假设我们有一个字符串,比如“ebgkjasjd”,现在我们需要将字符串中所有出现的辅音字母替换为最近的元音字母。 Input…

    2025年12月17日
    000
  • 将给定的字符串转换为T,通过任意次数替换字符串之间的字符

    转换字符串意味着我们必须根据给定条件将其与给定字符串相同。在这个问题中,我们给出了一个由字符串“arr”和大小为“M”的字符串“T”组成的数组。我们的任务是检查是否可以通过从数组的字符串( arr[i] )中删除任何字符并将该字符插入到另一个字符串的任何索引中来使数组中存在的所有字符串与给定的字符串…

    2025年12月17日
    000
  • 递归程序在C++中检查一个数字是否是回文数

    我们得到一个整数作为输入。目标是使用递归来确定输入数字 Num 是否为回文。 要检查一个数字是否为回文,请反转该数字并检查两个数字是否相同。如果反转后的数等于原数,则为回文。 示例 输入− Num = 34212; 输出− 34212 不是回文! 解释− 如果我们反转 34212,则得到 21243…

    2025年12月17日
    000
  • 将字符串A所需附加的最小子序列以获得字符串B

    在这个问题中,我们需要使用str1的子序列来构造str2。为了解决这个问题,我们可以找到str1的子序列,使其能够覆盖最大长度为str2的子串。在这里,我们将学习两种不同的方法来解决问题。 问题陈述 – 我们给出了两个不同长度的字符串:str1 和 str2。我们需要按照以下条件从 str1 构造 …

    2025年12月17日
    000
  • C程序用于判断给定的数字是否为强数

    一个强数是一个数字,其中各位数字的阶乘之和等于该数字本身。 示例 123!= 1!+2!+3!                    =1+2+6 =9 在这个例子中,123不是一个强数,因为各位数字的阶乘之和不等于该数字本身。 145!=1!+4!+5!             =1+24+120…

    2025年12月17日
    000
  • 找到通过插入给定数字形成的最小数字

    在给定的数字中插入一个数字意味着在给定的数字中添加一个新的数字,可以是在数字的前面、后面或者中间。我们已经给出了一个数字和一个数字,并且必须以尽可能小的方式将该数字添加到数字中。为了方便插入操作,我们将把数字转换为字符串。此外,给定的数字也可以是负数,因此我们必须考虑这种情况。 示例示例 Input…

    2025年12月17日
    000
  • 检查字符串是否包含连续的字母,并且每个字母只出现一次

    Introduction 在C++中,字符串是一系列的字符,这些字符可以是不同的或重复的。连续的字符是同时出现的字符,它们之间的差值为1。例如,字符a和b是连续的,因为它们一起出现。然而,字符m和o在它们的位置上有一个差值为2,使它们不是连续的。 在本文中,我们将开发一段代码,该代码将以字符串作为输…

    2025年12月17日
    000
  • 加密字符串

    加密是一种通过使用某些技术或某些步骤来更改数据的技术,使其更改为另一种信息或无法直接从中收集到先前的信息。对于加密,我们必须遵循针对特定加密类型固定的某些步骤。 在这个问题中,我们将得到一个字符串,我们必须按照给定的步骤对其进行加密 – 首先,我们必须获取包含相同字符的所有子字符串,并将…

    2025年12月17日
    000
  • 打印给定数字的乘法表在C中

    程序描述 打印给定数字的乘法表 算法 接受用户提供的任何需要形成乘法的数字 从 I 的值开始乘以给定数 (=1) 将给定数与 I 的值递增,直到 I 值小于或等于12. 示例 /* Program to print the multiplication table of a given number…

    2025年12月17日
    000
  • 在C语言中编写一个程序,用于检查一个字符串是否包含任何特殊字符

    给定一个字符串 str[],任务是检查字符串是否包含任何特殊字符,如果字符串有特殊字符,则打印“字符串不被接受”,否则打印“字符串被接受”。 特殊字符是那些既不是数字也不是字母的字符,即 – !@#$%^&*()+=-][‘;/.,{}|:”?`~ 因此,在C编程语言…

    2025年12月17日
    000
  • 查询字符串A中是否存在字符串B作为子字符串

    介绍 In this tutorial, we will see queries to check if string B exists as a substring of string A. A substring is a string that is part of the main stri…

    2025年12月17日
    000
  • 给定一个数字,编写一个C程序来找到斐波那契数列

    斐波那契数列是通过将前两个数字相加得到的一系列数字。 斐波那契数列从两个数字f0和f1开始。 fo和f1的初始值可以取0、1或1、1。 Fibonacci序列满足以下条件: fn = fn-1 + fn-2 算法 参考Fibonacci序列的算法。 STARTStep 1: Read integer…

    2025年12月17日
    000
  • 使用STL实现给定字符串的C++全排列

    当给定字符串的字符以任意形式重新排列时,就形成了字符串的排列。例如,在本教程中,我们将讨论如何使用 C++ 的标准模板库打印给定字符串的所有排列 Input : s = “ADT”Output : “ADT”, “ATD”, &…

    2025年12月17日
    000
  • C++程序:按字母顺序重新排列单词的位置

    在这个问题中,一个字符串被作为输入,我们必须按字典顺序对字符串中出现的单词进行排序。为此,我们为字符串中的每个单词(之间用空格区分)分配一个从 1 开始的索引,并以排序索引的形式获得输出。 String = {“Hello”, “World”}“Hello” = 1“World” = 2 由于输入字…

    2025年12月17日
    000
  • C语言中的字符串字面值是什么?

    字符串文字是一个以零结尾的字符序列。例如, Char * str = “hi, hello”; /* string literal */ 字符串字面量用于初始化数组。 char a1[] = “xyz”; /* a1 is char[4] holding {‘x’,’y’,’z’,”} */cha…

    2025年12月17日
    000
  • 可憎的数字

    如果一个数字在其二进制展开中有奇数个1,则被认为是奇异数。前10个奇异数是1,2,4,7,10,11,13,14,16,19,21。有趣的是,所有2的幂都是奇异数,因为它们只有1个位被设置。 下面的文章详细讨论了两种判断一个数字是否为可恶数字的方法。 问题陈述 这个问题的目的是检查给定的数字是否是一…

    2025年12月17日
    000
  • 用C++将一个数字表示为最大可能数量的质数之和

    讨论一个问题,例如,给定一个数字 N,我们需要将该数字拆分为最大素数和 Input: N = 7Output: 2 2 3Explanation: 7 can be represented as the sum of two 2’s and a 3 which are the maxim…

    2025年12月17日
    000
  • 使用C++编写代码,找到第N个非平方数

    我们都知道不是任何数字的平方的数字,如 2、3、5、7、8 等。非平方数有 N 个,不可能知道每个数字。因此,在本文中,我们将解释有关无平方数或非平方数的所有内容,以及在 C++ 中查找第 N 个非平方数的方法。 第 N 个非平方数 如果一个数是整数的平方,则该数被称为完全平方数。完全平方数的一些例…

    2025年12月17日
    000
  • 检查三个给定字符串的子字符串是否可以连接成回文串

    回文是计算机科学和编程中的一个迷人话题。回文是一个单词、短语、数字或其他字符序列,从前往后读和从后往前读是一样的,忽略空格、标点和大小写。在本文中,我们将研究一个独特的问题:如何确定从三个给定的字符串中的子字符串是否可以连接起来形成一个回文。这个问题是一个常见的面试题,可以使用各种技术来解决,包括字…

    2025年12月17日
    000
  • C++程序:找到具有相同左右旋转的数字的最长子序列

    在这个问题中,我们需要找到左右旋转相同的子序列的最大长度。左旋转是指将字符串中的所有字符向左移动,并将末尾的第一个字符移动。右旋转意味着将所有字符串字符向右移动,并将最后一个字符移动到开头。 问题陈述 – 我们给定了包含数字的字符串str,需要找到左右旋转相同的最大长度的子序列。 示例 输入-str…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信