蓝桥杯每日一题2023.10.11

子串分值和 - 蓝桥云课 (lanqiao.cn)

题目描述

题目分析

以下为50分方法(暴力枚举)

第一层循环枚举其长度,第二层循环枚举其左端点,k代表右端点,(将每一种子串一一枚举出来)算出从左端点到右端点的不同的字符,使用ans来记录最终的答案

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N = 2e5 + 10;
typedef long long ll;
ll ans;    
string s;
bool v[N];
ll sum(ll l, ll r)
{
    ll res = 0;
    for(ll i = l; i <= r; i ++)v[s[i] - '0'] = 0;
    for(ll i = l; i <= r; i ++)
    {
        if(!v[s[i] - '0'])
        {
            v[s[i] - '0'] = 1;
            res ++;
        }
    }
//    cout << res << '\n';
    return res;
}
int main()
{
    cin >> s;
    ll n = s.size();
    for(ll i = 1; i <= n; i ++)
    {
        for(ll j = 0; j < n; j ++)
        {
            ll k = j + i - 1;
            if(k < n)
            {
                ans += sum(j, k);
            //    cout << j << ' ' << k << '\n';
            }
        }
    }
    cout << ans;
    return 0;
}

满分解法:(使用DP)

使用pre记录上一次字符出现的位置

计算当前字符对整个字符串的贡献:

如果当前字符串没出现过,就是对整个字符串都有贡献,不然就只对上一次出现之后的排列做了贡献

eg.i == 1第一次出现,sum += 1 * 后面的长度

i == 6,在i == 3出现,sum += 3 * (6 - 3) [6 - 3为上一次出现之后的字符的长度(后面的长度)]

等号后面的第一个3为上一次i出现的位置

如下:ababc中第1个b可以提供8点贡献,(2 - 0) * (5 - 2 + 1) = 8

第2个b可以提供4点贡献,(4 - 2) * (5 - 4 + 1) = 4

eg.

opababc

第二个a做出贡献的字符串为babc的排列,opa(在第二个a之前已经被第一个a做过了贡献)

注意开long long

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 2e5 + 10;
string s;
ll sum, pre[N];
int main()
{
	cin >> s;
	ll n = s.size();
	s = '0' + s;
	for(ll i = 1; i <= n; i ++)
	{
		sum += (i - pre[s[i] - 'a']) * (n - i + 1);
		pre[s[i] - 'a'] = i;
	}
	cout << sum << '\n';
	return 0;
}
相关推荐
季明洵19 分钟前
反转字符串、反转字符串II、反转字符串中的单词
java·数据结构·算法·leetcode·字符串
2401_8414956424 分钟前
【Python高级编程】近似串匹配
python·算法·动态规划·字符串·数组·时间复杂度·空间复杂度
lingggggaaaa28 分钟前
安全工具篇&魔改二开&CheckSum8算法&Beacon密钥&Stager流量&生成机制
学习·算法·安全·web安全·网络安全·免杀对抗
Python+JAVA+大数据30 分钟前
SQL玩出算法竞赛高度!郑凌云数独算法:递归CTE+位运算DFS回溯全解析
数据库·sql·算法·搜索引擎·深度优先·dfs
MicroTech202533 分钟前
量子主成分分析(QPCA):微算法科技(NASDAQ :MLGO)重构图像降维与特征提取的技术
科技·算法·重构
历程里程碑35 分钟前
滑动窗口------滑动窗口最大值
大数据·python·算法·elasticsearch·搜索引擎·flask·tornado
Mr_Xuhhh35 分钟前
C语言字符串与内存操作函数模拟实现详解
java·linux·算法
B站_计算机毕业设计之家38 分钟前
AI大模型:Deepseek美食推荐系统 机器学习 协同过滤推荐算法+可视化 Django框架 大数据毕业设计(源码)✅
python·算法·机器学习·数据分析·django·推荐算法·美食
小草cys39 分钟前
基于大模型的图像目标检测及跟踪算法
人工智能·算法·目标检测
代码游侠1 小时前
C语言核心概念复习(三)
开发语言·数据结构·c++·笔记·学习·算法