热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

C++解决LeetCode1781:所有子字符串的美丽值总和

本文详细探讨了LeetCode1781题目“所有子字符串美丽值之和”的两种解法,包括使用前缀和的方法以及在遍历过程中直接计算的方法,提供了详细的C++实现代码。

LeetCode 1781:所有子字符串的美丽值总和


题目链接:LeetCode 1781


一个字符串的 美丽值 定义为其出现频率最高的字符与出现频率最低的字符之间的差值。



  • 例如,字符串 "abaacc" 的美丽值为 3 - 1 = 2。


给定一个字符串 s,任务是计算并返回其所有子字符串的美丽值之和。


示例


示例 1



输入:s = "aabcb"
输出:5
解释:美丽值不为零的子字符串包括 ["aab","aabc","aabcb","abcb","bcb"],每个字符串的美丽值均为 1。



示例 2



输入:s = "aabcbaa"
输出:17



提示



  • 字符串长度范围为 1 到 500。

  • 字符串仅由小写字母组成。


解决方案


方法一:利用前缀和


此方法首先构建一个二维数组来存储每个字符在不同位置的累积计数。通过这种方式,可以在后续计算任意子字符串时快速获取字符的最大和最小出现频率,从而计算美丽值。


class Solution {
public:
int beautySum(string s) {
int n = s.size();
vector> prefix(26, vector(n + 1));
for (int i = 1; i <= n; i++) {
for (int c = 0; c <26; c++) {
prefix[c][i] = prefix[c][i - 1];
}
prefix[s[i - 1] - 'a'][i]++;
}
int ans = 0;
for (int i = 0; i for (int j = i + 1; j int M = 0, m = 1000;
for (int c = 0; c <26; c++) {
int thisC = prefix[c][j + 1] - prefix[c][i];
M = max(M, thisC);
if (thisC) {
m = min(m, thisC);
}
}
ans += M - m;
}
}
return ans;
}
};

方法二:动态计算


这种方法避免了预先计算前缀和,而是随着遍历过程动态更新字符的出现频率。这种方法减少了额外的空间需求,同时保持了算法的时间效率。


class Solution {
public:
int beautySum(string s) {
int ans = 0;
int n = s.size();
for (int i = 0; i int cnt[26] = {0};
for (int j = i; j cnt[s[j] - 'a']++;
int M = 0, m = 1000;
for (int d = 0; d <26; d++) {
M = max(M, cnt[d]);
if (cnt[d])
m = min(m, cnt[d]);
}
ans += M - m;
}
}
return ans;
}
};

推荐阅读
  • 本文探讨了如何利用 Hibernate 进行高效的批量更新和删除操作,包括直接使用 Hibernate API 的方法及其局限性,以及如何通过 JDBC 或存储过程实现更优的性能。 ... [详细]
  • 深入理解Python中的sorted高阶函数
    排序是编程中常见的需求,无论是简单的数字排序还是复杂的对象排序,其核心都是比较两个元素。本文将探讨如何利用Python的高阶函数`sorted()`,通过自定义键函数来实现灵活多样的排序逻辑。 ... [详细]
  • 本文详细解析了‘溿’字在新华字典中的发音、笔画结构及常用组合,并探讨其在姓名学中的应用。 ... [详细]
  • 本周以来,我发现自己经常沉浸在美好的梦境中,这些梦大多与亲朋好友共度欢乐时光有关。虽然这些梦境令人愉快,但也导致我早晨难以醒来,这种感觉让我陷入了深思。 ... [详细]
  • 蚂蚁S19作为最新一代高性能矿机,依然保持着强大的爆发力,其算力高达95T,同时功耗保持在同期最低水平。 ... [详细]
  • 在编写 PHP 类时,经常会遇到因类未正确实例化而导致的 'function non-object' 错误。本文将详细探讨 PHP 构造函数中的双下划线使用方法及其常见问题。 ... [详细]
  • 本文详细介绍了汉字‘莋’在新华字典中的具体含义、正确的读音、笔画结构以及常用组合词语和在姓名学中的应用。 ... [详细]
  • 本文总结了MySQL的一些实用技巧,包括查询版本、修改字段属性、添加自动增长字段、备份与恢复数据库等操作,并提供了一些常见的SQL语句示例。 ... [详细]
  • Spring Cloud因其强大的功能和灵活性,被誉为开发分布式系统的‘一站式’解决方案。它不仅简化了分布式系统中的常见模式实现,还被广泛应用于企业级生产环境中。本书内容详实,覆盖了从微服务基础到Spring Cloud的高级应用,适合各层次的开发者。 ... [详细]
  • FPGA驱动步进电机精确转动_步进电机的工作原理与应用
    步进电机是一种将电脉冲信号转化为机械角位移的控制电机。每个电脉冲使电机转动一个固定角度,这一特性使其广泛应用于需要精确定位的场景中。 ... [详细]
  • Microsoft即将发布WPF/E的CTP(Community Technology Preview)和SDK,标志着RIA(Rich Internet Application)技术的新里程碑。更多详情及下载链接请参见MSDN官方页面。 ... [详细]
  • 本章探讨了使用固定数组实现栈和队列的基本方法,以及如何通过这些基本结构来实现更复杂的操作,如获取栈中的最小值。此外,还介绍了如何利用栈来模拟队列的行为,反之亦然。 ... [详细]
  • Web前端性能提升指南:简化JavaScript与消除重复脚本
    本文为Web前端性能优化系列的第七篇,重点探讨简化JavaScript代码及清除重复脚本的方法。通过这些技术,可以显著提高网页加载速度和用户体验。了解更多信息,请参阅我们的完整指南:Web前端性能优化。 ... [详细]
  • 探索JS与PHP生成随机数的方法及应用
    本文详细探讨了JavaScript和PHP两种编程语言中生成随机数的不同方法,特别关注于如何在特定条件下(如每隔10分钟)生成随机数,并确保数值在指定范围内,同时保持两位小数精度。 ... [详细]
  • 在使用Element UI构建后台管理界面时,遇到了一个常见的问题:页面上应显示的文字或组件位置仅显示了变量名。进一步检查发现,这是由于Vue-i18n库配置不当引起的。本文将详细介绍如何解决这一问题,并提供有效的解决方案。 ... [详细]
author-avatar
手机用户2602933827
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有