第十一屆藍橋杯大(dà)賽軟件類省賽第二場 H: 子(zǐ)串分值和(hé / huò) - 新聞資訊 - 雲南小程序開發|雲南軟件開發|雲南網站建設-昆明融晨信息技術有限公司

159-8711-8523

雲南網建設/小程序開發/軟件開發

知識

不(bù)管是(shì)網站,軟件還是(shì)小程序,都要(yào / yāo)直接或間接能爲(wéi / wèi)您産生價值,我們在(zài)追求其視覺表現的(de)同時(shí),更側重于(yú)功能的(de)便捷,營銷的(de)便利,運營的(de)高效,讓網站成爲(wéi / wèi)營銷工具,讓軟件能切實提升企業内部管理水平和(hé / huò)效率。優秀的(de)程序爲(wéi / wèi)後期升級提供便捷的(de)支持!

您當前位置>首頁 » 新聞資訊 » 技術分享 >

第十一屆藍橋杯大(dà)賽軟件類省賽第二場 H: 子(zǐ)串分值和(hé / huò)

發表時(shí)間:2020-10-19

發布人(rén):融晨科技

浏覽次數:87

在(zài)這(zhè)裏插入圖片描述
在(zài)這(zhè)裏插入圖片描述

題解

列舉每個(gè)左端點(l), 每個(gè)字母自力計算供獻,列舉每個(gè)字母,在(zài)【l, n】 中找到(dào)該字母第一次出(chū)現的(de)地(dì / de)位p, 則左端點爲(wéi / wèi) l, 右短點在(zài)【p, n】的(de)子(zǐ)串都獲得該字母的(de)供獻,供獻 n - p + 1。
例如 :

  • ccaba
  • 當 l = 1 時(shí) :
  • 列舉 ‘a’ , 第一次出(chū)現的(de)地(dì / de)位 p = 3 供獻 5 - 3 + 1 = 3。
  • 列舉 ‘b’ …
  • 當 l = 2 …

序列自念頭保護下一字符地(dì / de)位, 複雜度 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;
}

相關案例查看更多