F:牛牛的Link Power I

传送门

题意:

在这里插入图片描述

分析:

先把字符为1的位置放到一个p数组里 p 1 , p 2 , p 3 . . . . . . p c n t p_1,p_2,p_3......p_{cnt} p1,p2,p3......pcnt
然后我们发现数组的Link值为:
p c n t − p c n t − 1 + p c n t − p c n t − 2 + p c n t − p c n t − 3 + . . . . . . + p c n t − p 1 + p c n t − 1 − p c n t − 2 + . . . . . . + p c n t − 1 − p 1 + . . . . . . + p 2 − p 1 p_{cnt}-p_{cnt-1}+p_{cnt}-p_{cnt-2}+p_{cnt}-p_{cnt-3}+......+p_{cnt}-p_{1}+p_{cnt-1}-p_{cnt-2}+......+p_{cnt-1}-p_{1}+......+p_2-p_1 pcntpcnt1+pcntpcnt2+pcntpcnt3+......+pcntp1+pcnt1pcnt2+......+pcnt1p1+......+p2p1
从后往前看,他实际就是第k位的值乘以k-1减去前面k-1个的和
处理一个前缀和即可

代码:

#include <iostream>
#include <stdio.h>
#include <algorithm>
#include <string.h>
#include <vector>
#include <math.h>
#include <map>
#include <queue>
#include <set>
#define Pll make_pair
using namespace std;
typedef long long ll;
const int MAXN=2e5+50;
const int inf=0x3f3f3f3f;
const int mod=1e9+7;
const int phi=1e9+6;
char ch[MAXN];
ll p[MAXN];
ll sum[MAXN];
int main()
{
    int n;
    scanf("%d ",&n);
    int cnt=0;
    for(int i=1;i<=n;i++){
        scanf("%c",&ch[i]);
        if(ch[i]=='1')
            p[++cnt]=i;
    }
    for(int i=1;i<=cnt;i++)sum[i]=(sum[i-1]+p[i])%mod;
    ll ans=0;
    for(int i=cnt;i>=2;i--){
        ans=(ans+(i-1)*p[i]%mod-sum[i-1]+mod)%mod;
    }
    printf("%lld\n",ans%mod);
    return 0;
}
/*
 
 */
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
npm run dev启动项目报错如下应该如何解决? INFO Starting development server... 10% building 2/5 modules 3 active ...der\index.js??ref--13-0!F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\src\main.jsError: error:0308010C:digital envelope routines::unsupported at new Hash (node:internal/crypto/hash:71:19) at Object.createHash (node:crypto:133:10) at module.exports (F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\webpack\lib\util\createHash.js:135:53) at NormalModule._initBuildHash (F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\webpack\lib\NormalModule.js:417:16) at handleParseError (F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\webpack\lib\NormalModule.js:471:10) at F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\webpack\lib\NormalModule.js:503:5 at F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\webpack\lib\NormalModule.js:358:12 at F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\loader-runner\lib\LoaderRunner.js:373:3 at iterateNormalLoaders (F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\loader-runner\lib\LoaderRunner.js:214:10) at iterateNormalLoaders (F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\loader-runner\lib\LoaderRunner.js:221:10) at F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\loader-runner\lib\LoaderRunner.js:236:3 at runSyncOrAsync (F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\loader-runner\lib\LoaderRunner.js:130:11) at iterateNormalLoaders (F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\loader-runner\lib\LoaderRunner.js:232:2) at Array.<anonymous> (F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\loader-runner\lib\LoaderRunner.js:205:4) at Storage.finished (F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\enhanced-resolve\lib\CachedInputFileSystem.js:55:16) at F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\enhanced-resolve\lib\CachedInputFileSystem.js:91:9 node:internal/crypto/hash:71 this[kHandle] = new _Hash(algorithm, xofLen); ^ Error: error:0308010C:digital envelope routines::unsupported at new Hash (node:internal/crypto/hash:71:19) at Object.createHash (node:crypto:133:10) at module.exports (F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\webpack\lib\util\createHash.js:135:53) at NormalModule._initBuildHash (F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\webpack\lib\NormalModule.js:417:16) at handleParseError (F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\webpack\lib\NormalModule.js:471:10) at F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\webpack\lib\NormalModule.js:503:5 at F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\webpack\lib\NormalModule.js:358:12 at F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\loader-runner\lib\LoaderRunner.js:373:3 at iterateNormalLoaders (F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\loader-runner\lib\LoaderRunner.js:214:10) at Array.<anonymous> (F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\loader-runner\lib\LoaderRunner.js:205:4) at Storage.finished (F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\enhanced-resolve\lib\CachedInputFileSystem.js:55:16) at F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\enhanced-resolve\lib\CachedInputFileSystem.js:91:9 at F:\NMD_Link_Of_Things\thinglinks\thinglinks-ui\node_modules\graceful-fs\graceful-fs.js:123:16 at FSReqCallback.readFileAfterClose [as oncomplete] (node:internal/fs/read_file_context:68:3) { opensslErrorStack: [ 'error:03000086:digital envelope routines::initialization error' ], library: 'digital envelope routines', reason: 'unsupported', code: 'ERR_OSSL_EVP_UNSUPPORTED' } Node.js v18.16.0
最新发布
07-23
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值