自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(3)
  • 收藏
  • 关注

原创 AtCoder Beginner Contest 353补题(C、D)

由于Ai<10^8,两个数相加之和要么大于10^8,要么小于10^8,并且不会超过2*10^8。可以求出所有和的总值,每个数都要加(n-1)次,再减去取模少掉的值。min(n-j,n-i)防止j<i 的情况发生。如果a[i]作为前半部分,后面的数字有1位数则ans+=a[i]*10,有2位数则ans+=a[i]*100……有n位数则ans+=a[i]*n*10。如果a[i]作为后半部分,ans要加的是原数字,第i个数作为后半部分的次数是i-1。E题参考大佬的视频要用到字典树,还没学,过几天学了再写吧~

2024-05-16 13:35:42 520

原创 基础算法之前缀和与差分

求让b[l+1,r]都为0的要进行几次操作,首先正负可以配对,然后让b[l+1,r]里面都为0,那么要变的只有b[r+1]这题是二维差分,需要逐行差分,然后求前缀和,知道改变[l,r]区间时同时改变a[l]和a[r+1]就可写出代码。每次操作如果+1则b[l]+=1,b[r+1]-=1;如果-1则b[l]-=1,b[r+1]+=1。最后再改变b[r+1]和b[l],这两个是同时变的,这样求最终得到的数列可能有多少种。思路:区间[a,b]的区间和=s[b]-s[a-1]前缀和:指某个序列的前n项和。

2024-05-15 20:36:56 669

原创 基础算法之双指针(尺取)

思路是如果当前区间内有画家遗漏,一直更新右指针j直到每个画家至少有一幅画在区间里,然后更新左指针i删除画,如果删除a[i]后有画家没画了,再更新右指针。i指针控制区间左端,用j指针试错来扩展右端,出错时j指向合法区间右端点,则ans+=j-i+1。题目条件为非严格单调递增序列,可能有重复的数字出现,i和j所维护的区间内都是相同的数字,这些数减去a[k]为x,则方案数是j-i。由于是升序序列,j指针指向右端,i指针指向左端,sum维护这段数的和。部分代码思路参考b站up主:董晓算法。

2024-05-15 18:54:10 353

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除