AcWing 2868. 子串分值

文章目录

前言

还是实力不允许啊,要是实力允许我就一道一道中等题刷了。简单题真够呛。有些题看题解都是看老半天看不懂,假设是这种我是真感觉没必要钻研。我现在大三,要是看一遍题解看不懂就算了,果断放弃。真可以这么果断吗,不管是做题还是生活,真可以这么果断吗。看到省赛的数据还有部分的分数的,反正就是写个暴力放在那里就好了,准备明年的蓝桥杯和 9 月的 csp ,26 年 3 月的 csp 看时间,要是可以的话也参加一下。就当机试模拟考试了。查了一下,是三月底,那时候机试都结束了,那算了。

代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=100010;
int l[N],r[N],p[30];
char s[N];
typedef long long LL;
int main(){
    scanf("%s",s+1);//从下标为 1 的位置开始存
    int n=strlen(s+1);
    for(int i=1;i<=n;i++){
        int t=s[i]-'a';
        //p 的下标表示的是这个是啥字母
        l[i]=p[t];//最开始的时候因为是全局数组,所以是 0 ,这里是特判了一下边界情况
        p[t]=i;//相当于每次就是该元素左边的元素
    }//表示当前的元素的位置,循环这块有点巧妙
    for(int i=0;i<26;i++){//这里映射的是每一个字母的位置
        p[i]=n+1;//右边界
    }
    for(int i=n;i>=1;i--){
        int t=s[i]-'a';
        r[i]=p[t];
        p[t]=i;
    }
    LL ans=0;
        ans+=(LL)(i-l[i])*(r[i]-i);//贡献法
    for(int i=1;i<=n;i++){
    }
    cout<<ans<<endl;
    return 0;
}

思路

看了一下,五个零,是十万。我知道的算法就是排序,二分,O(nlogn) 这个时间复杂度。这个题是啥意思啊。从一个字符串里面截取一段字符串,计算这段字符串的 f 函数的数值,对于所有的函数值求和,输出这个和。这么复杂。看题解,理解了一部分,不想放弃。又看了一遍,大概懂了。这种就挺难受的。因为这种大概懂,把代码删掉自己很难独立写出来。每行写了注释之后感觉也还好,就是循环那块有点难。多写几遍就好了。贡献法的关键就是要找到某一个字母相邻的两个相同的字母,假设没有就找边界,因为从下标为 1 开始存的,所以边界就是 0 和 n+1 .

相关推荐
啊吧怪不啊吧17 分钟前
二分查找算法介绍及使用
数据结构·算法·leetcode
知识搬运工人24 分钟前
对比 DeepSeek(MLA)、Qwen 和 Llama 系列大模型在 Attention 架构/算法层面的核心设计及理解它们的本质区别。
算法
修行者Java1 小时前
JVM 垃圾回收算法的详细介绍
jvm·算法
AndrewHZ1 小时前
【图像处理基石】什么是光流法?
图像处理·算法·计算机视觉·目标跟踪·cv·光流法·行为识别
mjhcsp2 小时前
C++ 三分查找:在单调与凸函数中高效定位极值的算法
开发语言·c++·算法
立志成为大牛的小牛2 小时前
数据结构——四十二、二叉排序树(王道408)
数据结构·笔记·程序人生·考研·算法
Funny_AI_LAB4 小时前
李飞飞联合杨立昆发表最新论文:超感知AI模型从视频中“看懂”并“预见”三维世界
人工智能·算法·语言模型·音视频
RTC老炮7 小时前
webrtc降噪-PriorSignalModelEstimator类源码分析与算法原理
算法·webrtc
草莓火锅9 小时前
用c++使输入的数字各个位上数字反转得到一个新数
开发语言·c++·算法
散峰而望9 小时前
C/C++输入输出初级(一) (算法竞赛)
c语言·开发语言·c++·算法·github