博客
关于我
第十一届十月份蓝桥杯省赛 H - 子串分值和:求字符串所有子串的不同字符个数和(思维/线段树)
阅读量:320 次
发布时间:2019-03-04

本文共 1092 字,大约阅读时间需要 3 分钟。

?????????????????????????????

  • ???????last???????????????
  • ????????????c?????????????????
  • ????????i????????????????prev???????(i - prev) * (n - i + 1)?
  • ????????????????
  • ???????????

    ????

  • ????????????last??????????????????????26???26?????????-1?
  • ?????????????????????????????last???
  • ??????????????????i????????????????prev???????(i - prev) * (n - i + 1)?
  • ??????????????????????????
  • ????

    #include 
    using namespace std;
    int main() {
    char s[] = "abcdabca";
    int n = strlen(s);
    int last[26] = {-1}; // ????????????
    long long ans = 0;
    for (int i = 0; i < n; ++i) {
    char c = s[i];
    int idx = c - 'a';
    if (last[idx] != -1) {
    // ????
    ans += (i - last[idx]) * (n - i + 1);
    }
    // ???????
    last[idx] = i;
    }
    cout << ans << endl;
    return 0;
    }

    ????

  • ??????last???????????????????????-1????????
  • ????????????????????c??????idx?
  • ?????????c???last?????????????????????last[idx]???????(i - last[idx]) * (n - i + 1)????ans??
  • ?????????????i???last[idx]?????????
  • ??????????????ans?
  • ???????????O(n)??????????????

    转载地址:http://siqq.baihongyu.com/

    你可能感兴趣的文章
    MySQL高级-MySQL并发参数调整
    查看>>
    MySQL高级-视图
    查看>>
    MySQL:判断逗号分隔的字符串中是否包含某个字符串
    查看>>
    Nacos在双击startup.cmd启动时提示:Unable to start embedded Tomcat
    查看>>
    Nacos安装教程(非常详细)从零基础入门到精通,看完这一篇就够了
    查看>>
    Nacos配置中心集群原理及源码分析
    查看>>
    nacos配置自动刷新源码解析
    查看>>
    Nacos集群搭建
    查看>>
    nacos集群搭建
    查看>>
    Navicat for MySQL 查看BLOB字段内容
    查看>>
    Neo4j电影关系图Cypher
    查看>>
    Neo4j的安装与使用
    查看>>
    Neo4j(2):环境搭建
    查看>>
    Neo私链
    查看>>
    nessus快速安装使用指南(非常详细)零基础入门到精通,收藏这一篇就够了
    查看>>
    Nessus漏洞扫描教程之配置Nessus
    查看>>
    Nest.js 6.0.0 正式版发布,基于 TypeScript 的 Node.js 框架
    查看>>
    NetApp凭借领先的混合云数据与服务把握数字化转型机遇
    查看>>
    NetBeans IDE8.0需要JDK1.7及以上版本
    查看>>
    netcat的端口转发功能的实现
    查看>>