首页 > 其他分享 >CF 1996 E. Decode(*1600) 思维+前缀和

CF 1996 E. Decode(*1600) 思维+前缀和

时间:2024-09-02 14:35:57浏览次数:16  
标签:const 前缀 1996 int 1600 CF 区间 mod define

CF 1996 E. Decode(*1600) 思维+前缀和

题目链接

题意

给你一个长度为 \(n\) 的二进制字符串,求出所有的子区间的所有满足 \(0\) 的个数等于 \(1\) 的个数的子区间个数之和。

思路

首先,求一段区间是否满足 \(0\) 的数量是否等于 \(1\) 的个数,是非常经典的做法,我们只需要维护一个数组,遇到 \(0\) ,就赋值 \(-1\) ,否则赋值 \(1\) 。那么只要这段区间的区间和为0,即可满足条件,那么只需要前缀和数组的两个值相同即可。

对于本题,我们可以直接去考虑每个满足条件区间的贡献,很简单的乘法原理,左端点可选位置 \(\times\) 右端点可选位置,求和即可。

代码

#include<bits/stdc++.h>

using namespace std;

#define ff first
#define ss second
#define pb push_back
#define all(u) u.begin(), u.end()
#define endl '\n'
#define debug(x) cout<<#x<<":"<<x<<endl;

typedef pair<int, int> PII;
typedef long long LL;
const int inf = 0x3f3f3f3f;
const int N = 1e5 + 10, M = 105;
const int mod = 1e9 + 7;
const int cases = 1;

void Showball(){
   string s;
   cin>>s;
   int n=s.size();
   s="?"+s;
   vector<int> a(n+1);
   for(int i=1;i<=n;i++){
      a[i]=a[i-1];
      if(s[i]=='1') a[i]++;
      else a[i]--;
   } 
   map<int,int> suf;
   LL ans=0;
   for(int i=n;i>=1;i--){
    suf[a[i]]+=(n-i+1);
    ans=(ans+1LL*i*suf[a[i]]%mod)%mod;
   }
   cout<<ans<<endl;
}
int main(){
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    cout.tie(nullptr);
    int T=1;
    if(cases) cin>>T;
    while(T--)
    Showball();
    return 0;
}

标签:const,前缀,1996,int,1600,CF,区间,mod,define
From: https://www.cnblogs.com/showball/p/18392675

相关文章

  • CF 2001 D. Longest Max Min Subsequence(*1900) 思维
    CF2001D.LongestMaxMinSubsequence(*1900)思维题目链接题意:给你一个长度为\(n\)的序列\(a\),设\(S\)是\(a\)的所有可能的非空子序列的集合,且没有重复的元素。你的目标是找出\(S\)中最长的序列。如果有多个序列,请找出将奇数位置上的项乘以\(−1\)后,使词序最小......
  • CF 2002 D1. DFS Checker (Easy Version) (*1900)思维
    CF2002D1.DFSChecker(EasyVersion)(*1900)思维题目链接题意:给你一棵\(n\)个节点组成的完全二叉树,并给出一个排列\(p\)。接下来进行\(q\)次询问。每次询问给你\(x\)和\(y\),你需要交换\(p_x\)和\(p_y\)。并且回答交换之后的排列\(p\)是否是这棵完全二叉树......
  • CF 2004 D. Colored Portals (*1600) 二分
    CF2004D.ColoredPortals(*1600)二分题目链接题意:有\(n\)座城市,编号从\(1\)到\(n\)。传送门一共有\(4\)种颜色,每个城市有两种不同颜色的传送门。若城市\(i\)和城市\(j\)有相同颜色的传送门。那么就可以花费\(|i-j|\)枚金币从城市\(i\)到城市\(j\)。\(q\)......
  • CF2008场题解
    Sakurako'sExam算法:模拟,分类讨论。题意简述:给\(a\)个数字\(1\)和\(b\)个数字\(2\),问能否在每个数字前加上加减号使得原始值为\(0\)。考虑\(1\)的个数如果是奇数,那么一定不行。否则如果\(2\)的个数是偶数,一定可以。当\(2\)的个数为奇数且还可能可以时,判断是否存......
  • CF1826D
    CF1826D链接:Problem-1826D-Codeforces题目大意:给你一个数组,让你选择一个区间\([l,r]\)设选中的区间为\(b\),\(b_{i_1}+b_{i_2}+b_{i_3}\)为区间内前三大的值,你需要选择一个区间使得\(b_{i_1}+b_{i_2}+b_{i_3}-(r-l)\)值最大,输出最大值思路:我们发现......
  • CF2003
    CF2003A考虑特殊情况,划分为\(2\)个串,判定\(s_1\nes_n\)即可B具有单调性,二分判定或者考虑贪心,考察\(\min\),先手必然要删,且随时能删,删了会让后面条件更容易满足,所以第一个删,归纳即可trick:枚举判定$\rightarrow$二分C贪心,每次选择最大和次大填即可D1&D2D1是\(......
  • CF2006
    CF2006A发现\(01\)和\(10\)相差不超过\(1\),就是关注\(01\)段个数,中间插入\(01\)不影响段的奇偶性,转化为路径首尾不同一种较优策略是先手固定根,其实还可以让后手固定根,当\(c_0=c_1\)答案可能会大\(1\),分讨即可B显然一条边只属于两条路径,暴力维护即可C考虑证明当......
  • CCF-CSP 2024 --重塑矩阵1,2c语言题解
     创作想法是因为像我当初大一时候想参加一些比赛但是奈何只学了c和c相关数据结构,但是对于许多竞赛的题目的题解往往都是c++或者其他面向对象的编程语言,让我们难以在c语言基础上入手这些比较复杂的题目。 创造的目的是为了帮助各位同时提高我对c语言编程的理解和锻炼个人......
  • CF1741F-Multi-ColoredSegments
    https://www.luogu.com.cn/problem/CF1741Fhttps://codeforces.com/contest/1741/problem/F参考:https://www.luogu.com.cn/article/bb54tb8m考虑用线段树维护每个点被几条线段覆盖,然后按照颜色分类,每次做其中一类,把同类颜色从线段树中去掉,然后先区间求和看有没有重叠,再左端点往......