在这个问题中,我们需要对每个字符串前缀执行给定的操作。最后,我们需要统计每个字符的频率。
我们可以采用贪心算法来解决这个问题。我们需要取长度为K的每个前缀,并根据给定的条件更新其字符。我们可以使用map来计算最终字符串中字符的频率。
问题陈述 - 我们给出了包含 N 个小写字母字符的字符串 tr。另外,我们还给出了映射列表,总共包含 26 个元素。每个元素根据其值映射到小写字符。例如,mapping[0] 映射到“a”,mapping[1] 映射到“b”,mapping[25] 映射到“z”。此外,映射数组包含 1 或 -1。
我们需要执行以下操作。
从长度为K的前缀中获取最大字符,并从'mapping'数组中获取映射值。
如果映射值为1,则将所有前缀元素增加1。
如果映射的值为-1,则将所有前缀元素减1。
在这里,增加元素意味着 ‘a’ −> ‘b’,‘b’ −> ‘c’,… ‘z’ −> ‘a’。
递减的元素意味着,‘a’->‘z’,‘b’->‘a’,…。 ‘z’->‘y’。
我们需要对每个长度为1的前缀执行上述操作
示例示例
输入
mapping = {-1, 1, 1, -1, 1, 1, -1, -1, -1, 1, 1, 1, -1, 1, -1, 1, -1, 1, -1, 1, 1, 1, -1, 1, 1, 1}, S = ‘progress’
输出
0 0 0 1 0 1 0 0 0 0 0 0 1 0 0 2 2 1 0 0 0 0 0 0 0 0
说明
在长度为1的前缀中,最大的字符是 'p',映射为 -1。因此,更新后的字符串将是 'orogress'。
长度为2的前缀中,最大字符为‘r’,映射为-1。因此,更新后的字符串将是“nqogress”。
在长度为3的前缀中,最大的字符是‘q’,映射值为1。因此,更新后的字符串为‘orpgress’。
当我们完成所有操作后,最终的字符串将是'pqmfpdqr',其中包含1个'f',2个'p',2个'q',1个'm',1个'd'和1个'd' 'r'。在输出中,我们打印了结果字符串中每个字符的频率。
输入
mapping = {-1, 1, 1, -1, 1, 1, -1, -1, -1, 1, 1, 1, -1, 1, -1, 1, -1, 1, -1, 1, 1, 1, -1, 1, 1, 1}, S = "ab",
输出
1 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
解释− 在执行所有操作之后,最终的字符串是'ac',我们打印了每个字符的频率。
方法一
在这种方法中,我们将遍历字符串并取K的值等于索引P。之后,我们将取长度等于P的前缀,找到最大字符,取映射值,并相应地更新所有前缀字符。
算法
步骤 1 − 定义‘max_char’变量来存储给定前缀的最大字符。
步骤2 − 同样地,用零初始化长度为26的列表,以便存储最终字符串中每个字符的频率。
第 3 步- 开始遍历字符串,并在循环内用 96 初始化“max_char”变量。
第 4 步- 使用嵌套循环从长度为 p 的前缀中查找最大字符。
步骤 5 - 通过添加 max_char 的映射值来更新前缀的每个字符。
第 7 步- 如果更新的字符小于“a”,则将其更新为“z”。
第 8 步- 如果更新的字符大于“z”,则将其更新为“a”。
第9步− 最后,通过遍历更新后的字符串,将每个字符的频率存储在列表中。
第 10 步- 打印字符的频率。
示例
#include <bits/stdc++.h> using namespace std; void performOperations(string &str, vector<int> &mapping) { int len = str.length(); char max_char; // array to store the final frequency of each character int freq[26] = {0}; for (int p = 0; p < len; p++) { max_char = 96; // Get the maximum character from the prefix string for (int q = 0; q <= p; q++) { max_char = max(max_char, str[q]); } // Update the prefix string by adding the max character's value. for (int q = 0; q <= p; q++) { // adding the mapping value to the current character str[q] += mapping[max_char - 'a']; // If the updated value is greater than z or less than a, update it if (str[q] < 'a') { str[q] = 'z'; } else if (str[q] > 'z') { str[q] = 'a'; } } } // Counting frequency of each character for (int p = 0; p < len; p++) { freq[str[p] - 'a']++; } // print count of each character in the updated string for (auto ch : freq) { cout << ch << ' '; } } int main() { string S = "progress"; vector<int> mapping = {-1, 1, 1, -1, 1, 1, -1, -1, -1, 1, 1, 1, -1, 1, -1, 1, -1, 1, -1, 1, 1, 1, -1, 1, 1, 1}; performOperations(S, mapping); return 0; }
输出
0 0 0 1 0 1 0 0 0 0 0 0 1 0 0 2 2 1 0 0 0 0 0 0 0 0
时间复杂度− O(N*N)因为我们使用两个嵌套循环遍历字符串。
空间复杂度− O(1),因为我们使用恒定空间来存储字符的频率。
结论
我们对输入字符串执行了给定的操作,并在输出中打印了更新后字符串的字符频率。程序员还可以使用C++中的map来存储字符频率,而不是使用列表。对于更多练习,程序员可以尝试打印更新后字符串中每个字符的累积频率。
以上是执行描述的操作后,每个长度为1到N的前缀中的每个小写字符的计数的详细内容。更多信息请关注PHP中文网其他相关文章!

C 持续使用的理由包括其高性能、广泛应用和不断演进的特性。1)高效性能:通过直接操作内存和硬件,C 在系统编程和高性能计算中表现出色。2)广泛应用:在游戏开发、嵌入式系统等领域大放异彩。3)不断演进:自1983年发布以来,C 持续增加新特性,保持其竞争力。

C 和XML的未来发展趋势分别为:1)C 将通过C 20和C 23标准引入模块、概念和协程等新特性,提升编程效率和安全性;2)XML将继续在数据交换和配置文件中占据重要地位,但会面临JSON和YAML的挑战,并朝着更简洁和易解析的方向发展,如XMLSchema1.1和XPath3.1的改进。

现代C 设计模式利用C 11及以后的新特性实现,帮助构建更灵活、高效的软件。1)使用lambda表达式和std::function简化观察者模式。2)通过移动语义和完美转发优化性能。3)智能指针确保类型安全和资源管理。

C 多线程和并发编程的核心概念包括线程的创建与管理、同步与互斥、条件变量、线程池、异步编程、常见错误与调试技巧以及性能优化与最佳实践。1)创建线程使用std::thread类,示例展示了如何创建并等待线程完成。2)同步与互斥使用std::mutex和std::lock_guard保护共享资源,避免数据竞争。3)条件变量通过std::condition_variable实现线程间的通信和同步。4)线程池示例展示了如何使用ThreadPool类并行处理任务,提高效率。5)异步编程使用std::as

C 的内存管理、指针和模板是核心特性。1.内存管理通过new和delete手动分配和释放内存,需注意堆和栈的区别。2.指针允许直接操作内存地址,使用需谨慎,智能指针可简化管理。3.模板实现泛型编程,提高代码重用性和灵活性,需理解类型推导和特化。

C 适合系统编程和硬件交互,因为它提供了接近硬件的控制能力和面向对象编程的强大特性。1)C 通过指针、内存管理和位操作等低级特性,实现高效的系统级操作。2)硬件交互通过设备驱动程序实现,C 可以编写这些驱动程序,处理与硬件设备的通信。

C 适合构建高性能游戏和仿真系统,因为它提供接近硬件的控制和高效性能。1)内存管理:手动控制减少碎片,提高性能。2)编译时优化:内联函数和循环展开提升运行速度。3)低级操作:直接访问硬件,优化图形和物理计算。

文件操作难题的真相:文件打开失败:权限不足、路径错误、文件被占用。数据写入失败:缓冲区已满、文件不可写、磁盘空间不足。其他常见问题:文件遍历缓慢、文本文件编码不正确、二进制文件读取错误。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

Atom编辑器mac版下载
最流行的的开源编辑器

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

Dreamweaver Mac版
视觉化网页开发工具

记事本++7.3.1
好用且免费的代码编辑器