第十一届蓝桥杯大赛软件类省赛第二场 H: 子串分值和 - 新闻资讯 - 云南小程序开发|云南软件开发|云南网站建设-昆明葵宇信息科技有限公司

159-8711-8523

云南网建设/小程序开发/软件开发

知识

不管是网站,软件还是小程序,都要直接或间接能为您产生价值,我们在追求其视觉表现的同时,更侧重于功能的便捷,营销的便利,运营的高效,让网站成为营销工具,让软件能切实提升企业内部管理水平和效率。优秀的程序为后期升级提供便捷的支持!

您当前位置>首页 » 新闻资讯 » 技术分享 >

第十一届蓝桥杯大赛软件类省赛第二场 H: 子串分值和

发表时间:2020-10-19

发布人:葵宇科技

浏览次数:72

在这里插入图片描述
在这里插入图片描述

题解

列举每个左端点(l), 每个字母自力计算供献,列举每个字母,在【l, n】 中找到该字母第一次出现的地位p, 则左端点为 l, 右短点在【p, n】的子串都获得该字母的供献,供献 n - p + 1。
例如 :

  • ccaba
  • 当 l = 1 时 :
  • 列举 ‘a’ , 第一次出现的地位 p = 3 供献 5 - 3 + 1 = 3。
  • 列举 ‘b’ …
  • 当 l = 2 …

序列自念头保护下一字符地位, 复杂度 O(26 * n)

#pragma GCC optimize(2)
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair<int, int> pii;
typedef vector<int> vi;
const int maxn = 2e5 + 10, mod = 1e9 + 7, inf = 0x3f3f3f3f;

char s[maxn]; int n, nxt[maxn][30];
void init()
{
    for(int i = n; i >= 1; i--)
    {
        for(int j = 1; j <= 26; j++)
            nxt[i-1][j] = nxt[i][j];
        nxt[i-1][s[i]-'a'+1] = i;
    }
}

int main()
{
    ios::sync_with_stdio(0);
    cin.tie(0);
    cin >> s + 1;
    n = strlen(s + 1);
    init();
    ll ans = 0;
    for(int i = 1; i <= n; i++)
    {
        for(int j = 1; j <= 26; j++)
        {
            int p = nxt[i-1][j];
            if(p == 0) continue;
            ans += (n - p + 1);
        }
    }
    cout << ans << endl;
    return 0;
}

相关案例查看更多