[蓝桥杯 2020 省 AB2] 子串分值

一.题目

题目描述

对于一个字符串 S,我们定义 S 的分值 f(S)S 中恰好出现一次的字符个数。

例如 f(“aba”)=1,f(“abc”)=3, f(“aaa”) = 0

现在给定一个字符串 S[0…n−1](长度为 n),请你计算对于所有 S 的非空子串 S[i…j](0 ≤ i ≤ j < n), f(S[i…j]) 的和是多少。

输入格式

输入一行包含一个由小写字母组成的字符串 S

输出格式

输出一个整数表示答案。

数据范围

对于 20% 的评测用例,1 ≤ n ≤ 10
对于 40% 的评测用例,1 ≤ n ≤ 100
对于 50% 的评测用例,1 ≤ n ≤ 1000
对于 60% 的评测用例,1 ≤ n ≤ 10000
对于所有评测用例,1 ≤ n ≤ 100000

输入样例1

ababc

输出样例1

21

二.解释

看完题目,先交手暴力代码,暴力代码直接写就好,后面会给出来,只能过50%。

我们从单独一个字符入手,以 cababcab 为例,第四个字符为 a, 对于这个 a 来说,它对所有只包含这一个 a 的子串有贡献,即所有只包含这一个 a 的子串的 f() 值都有它。

省去其余字符只保留 a ,得 ·a·a··a,下标从 1 开始·。

设所有只包含中间 a 的子串数为 x,中间 a 下标为 K,左一个 a 下标位 L ,有一个 a 下标为 R;

a k a_k ak 左边取子串的首位有 (K - L) 种取法,右边取子串的末位有 (R - K) 种取法;

则:x = (K - L) * (R - K);

这一要注意一下边界情况:
a K a_K aK 为第一个 a 时,我们认为在下标 0 处有一个 a;
a K a_K aK 为最后一个 a 时,我们认为在下标 n + 1 处有一个 a;
这样按照上面的公式算出来的结果才是正确的。

三.代码

AC代码:
暴力代码:
#include <iostream>
#include <unordered_map>
#include <algorithm>
#include <cstring>
#include <string>
#include <vector>
#include <queue>
#include <set>using namespace std;typedef unsigned long long int64;
const int MaxN = 1e5 + 10;int InN, InK, Res;
string InS;
unordered_map<char, int> Hash[MaxN];
set<char> C[MaxN];int main()
{cin >> InS;for (int i = 0; i < InS.size(); i++){unordered_map<char, int> Map;	//从i开始每个字符的出现次数Map[InS[i]]++;int Count = 1;		//统计当前子串不重复字符的个数Res++;		//单独一个字符作为子串的情况for (int j = i + 1; j < InS.size(); j++){if (Map[InS[j]] == 1) { Res += --Count; }else if (Map[InS[j]] > 1) { Res += Count; }else { Res += ++Count; }Map[InS[j]]++;}}cout << Res;return 0;
}
AC代码:
#include <iostream>
#include <unordered_map>
#include <algorithm>
#include <cstring>
#include <string>
#include <vector>
#include <queue>
#include <set>using namespace std;typedef unsigned long long int64;
const int MaxN = 1e5 + 10;int64 InN, InK, Res;
string InS;
int L[MaxN], R[MaxN], Pre[30];	//对于下标为i的字符来说:L[i]左一个字串出现的下标,R[i]右一个字串出现的下标,Pre[i]临时存放上一个字符出现的位置int main()
{cin >> InS;//求L[i]for (int i = 1; i <= InS.size(); i++){//字符串下标默认从0开始,所以这里要减一int Tmp = InS[i - 1] - 'a';L[i] = Pre[Tmp];Pre[Tmp] = i;}//求R[i]for (int i = 0; i < 30; i++) { Pre[i] = InS.size() + 1; }for (int i = InS.size(); i > 0; i--){//字符串下标默认从0开始,所以这里要减一int Tmp = InS[i - 1] - 'a';R[i] = Pre[Tmp];Pre[Tmp] = i;}for (int i = 1; i <= InS.size(); i++){Res += (int64)(i - L[i]) * (R[i] - i);}cout << Res;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/18359.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

嵌入式学习——3——域套接字UNIX

1、域套接字UNIX 1、域套接字是最原始的套接字通信方式&#xff0c;是完成同一主机之间多个进程间通信 2、由于不需要跨主机进行通信了&#xff0c;那么就无需使用ip地址和端口号了 3、通信本质&#xff1a;依然使用的是内核空间 4、域套接字的通信介质为套接字文件 bcd-lsp 5、…

低代码技术:数字经济时代的崛起与变革

随着数字经济时代的到来&#xff0c;低代码技术作为一种创新性工具正迅速崛起。本文将介绍低代码技术的定义和特点&#xff0c;并探讨其在数字经济中的重要性和应用。同时&#xff0c;我们将讨论低代码技术对传统软件开发方式的改变以及其带来的商业与创新机会。 引言 随着数字…

如何解决链游中可能出现的延迟或网络拥堵问题?

随着区块链技术的不断发展和普及&#xff0c;链游&#xff08;基于区块链的游戏&#xff09;作为新兴的娱乐形式&#xff0c;正逐渐走进大众的视野。然而&#xff0c;与传统游戏相比&#xff0c;链游在运行过程中可能会遇到一些特有的问题&#xff0c;其中最为突出的就是延迟和…

GB-T 37973-2019 信息安全技术 大数据安全管理指南

编写背景 随着大数据技术的快速发展和广泛应用&#xff0c;数据安全问题日益凸显。大数据安全管理指南的编写旨在指导和规范大数据在采集、存储、处理、传输、共享和销毁等环节的安全管理工作&#xff0c;以确保数据的完整性、可用性和 保密性&#xff0c;同时促进大数据的健康…

Oracle中clob怎么拼接字符

在Oracle数据库中&#xff0c;拼接字符主要有以下几种方法&#xff0c;我会以清晰的方式为您解释&#xff1a; 使用“||”操作符 这是Oracle中常用的字符串拼接方法。 语法示例&#xff1a;SELECT Hello || World AS result FROM dual; 输出结果&#xff1a;Hello World …

ES脚本启动报错修改

使用自写脚本启动ES集群时&#xff0c;添加安全策略时报错如下&#xff1a; Positional arguments not allowed, found [ -E xpack.security.enabledtrue -E xpack.security.transport.ssl.enabledtrue -E xpack.license.self_generated.typebasic -E xpack.security.transpor…

宝塔下应该用 Memcached 还是 Redis?

明月最近在跟几个使用宝塔面板的客户运维的时候发现不少站长不知道如何选择 Memcached 和 Redis&#xff0c;甚至都说不清楚 Memcached 或者 Redis 具体是用来干啥的&#xff1f;甚至还碰到过一个站长 Memcached 和 Redis 都安装了&#xff0c;但一个都没有用&#xff0c;就那么…

希尔排序法

希尔排序为插入排序的优化&#xff0c;即将数组分组&#xff0c;将每一组进行插入排序&#xff0c;每一组排成有序后&#xff0c;最后整体就变有序了。 上面gap2&#xff0c;即5&#xff0c;14&#xff0c;18&#xff0c;27&#xff0c;68为一组&#xff1b;13&#xff0c;20&a…

Numba 的 CUDA 示例(1/4):踏上并行之旅

按照本系列从头开始使用 Python 学习 CUDA 编程 介绍 GPU&#xff08;图形处理单元&#xff09;&#xff0c;顾名思义&#xff0c;最初是为计算机图形学开发的。从那时起&#xff0c;它们几乎在每个需要高计算吞吐量的领域都无处不在。这一进步得益于 GPGPU&#xff08;通用 G…

Java基础:基本语法(一)

Java基础&#xff1a;基本语法&#xff08;一&#xff09; 文章目录 Java基础&#xff1a;基本语法&#xff08;一&#xff09;1. 前言2. 开发环境搭建2.1 Java开发工具包下载2.2 环境变量配置2.3 Java程序的运行过程 3. 数据类型3.1 基本数据类型3.2 引用数据类型 4. 常量与变…

安装GO环境

#windows 1.下载go的安装包msi,下载完双击运行,指定一个目录进行安装 #msi安装时,会自动设置以下环境变量: #GOPATH(默认设置为C:\Users\hhx\go), #C:\Users\hhx\go\bin, #go安装位置下的bin目录 2.检查是否安装成功,终端中运行go version解释一些环境变量 GOROOT:go的安装位置…

ping不通ip的解决方法

解决ping不通IP的问题可以通过以下几种方法&#xff1a; 1.检查IP配置&#xff1a;确保所有设备的IP地址、子网掩码和默认网关配置正确。如果使用DHCP&#xff0c;请确认设备已设置为自动获取IP地址&#xff0c;并检查DHCP服务器的地址池配置是否正确且未耗尽。 2.检查网络设…

opencascade V3d_PositionLight V3d_SpotLight 源码学习 (位置性)光源

Positional、Spot 和 Directional Light 类的基类。 类V3d_SpotLight 创造和修改光源的衰减因子 F 决定了表面的照明&#xff1a; F 1 / (ConstAttenuation() LinearAttenuation() * Distance) 其中 Distance 是从光源到表面的距离。默认值 (1.0, 0.0) 对应最小的衰减。浓…

【做一道算一道】力扣332.重新安排行程

332.重新安排行程 给定一个机票的字符串二维数组 [from, to]&#xff0c;子数组中的两个成员分别表示飞机出发和降落的机场地点&#xff0c;对该行程进行重新规划排序。所有这些机票都属于一个从 JFK&#xff08;肯尼迪国际机场&#xff09;出发的先生&#xff0c;所以该行程必…

navicat连接过的库忘记密码

1、点击文件->导出连接 2、勾选想要知道密码的库 3、打开导出的文件搜索Password 4、复制Password解密 把下面的php代码复制到在线运行php的网站&#xff0c;替换最下面的decrypt(‘B7246A6E64D4F50A563FA20427A47991’)括号里的内容&#xff0c;然后执行php代码&#xff0…

Linux--进程间通信(1)(匿名管道)

目录 1.了解进程通信 1.1进程为什么要通信 1.2 进程如何通信 1.3进程间通信的方式 2.管道 2.1管道的初步理解 2.2站在文件描述符的角度-进一步理解管道 2.3 管道的系统调用接口&#xff08;匿名管道&#xff09; 2.3.1介绍接口函数&#xff1a; 2.3.2编写一个管道的代…

nd4j-native-platform for Mac 指南

nd4j-native-platform for Mac 指南 在使用nd4j-native-platform作为依赖于Mac OS的项目时&#xff0c;你需要确保正确地配置了Maven或Gradle构建文件以适应Mac操作系统。nd4j-native-platform依赖包含了ND4J库针对特定平台的本地二进制实现&#xff0c;这包括CPU和可能的GPU支…

通过date命令给日志文件添加日期

一、背景 服务的日志没有使用日志工具&#xff0c;每次重启后生成新日志文件名称相同&#xff0c;新日志将会把旧日志文件冲掉&#xff0c;旧日志无法保留。 为避免因旧日志丢失导致无法定位问题&#xff0c;所以需要保证每次生成的日志文件名称不同。 二、解决 在启动时&am…

SQLI-labs-第二十六关和第二十六a关

目录 第二十六关 1、判断注入点 2、判断数据库 3、判断表名 4、判断字段名 5、获取数据库的数据 第二十六a关 第二十六关 知识点&#xff1a;绕过and、or、空格、注释符等过滤 思路 通过源代码&#xff0c;我们可以知道&#xff0c;数据库对用户的输入进行了过滤&…

【校园网网络维修】当前用户使用的IP与设备重定向地址中IP不一致,请重新认证

出现的网络问题&#xff1a;当前用户使用的IP与设备重定向地址中IP不一致&#xff0c;请重新认证 可能的原因&#xff1a; 把之前登录的网页收藏到浏览器&#xff0c;然后直接通过这个链接进行登录认证。可能是收藏网址导致的ip地址请求参数不一致。 解决方法&#xff1a; 方法…