AtCoder Beginner Contest 164 D.Multiple of 2019

AtCoder Beginner Contest 164 D.Multiple of 2019

AtCoder Beginner Contest 164 D.Multiple of 2019_第1张图片
这题感觉有印象,就是从后往前 d p dp dp,有重复的加上重复的即可,AC代码如下:

#include
using namespace std;
typedef long long ll;
int main()
{
    string s;
    cin>>s;
    int len=s.size();
    ll ans=0,p=1,now=0,cnt[2020]={0};
    cnt[0]=1;
    for(int i=len;i--;)
    {
        now=(now+ll(s[i]-'0')*p)%2019;
        ans+=cnt[now]++;
        p=p*10%2019;
    }
    cout<<ans<<endl;
    return 0;
}

你可能感兴趣的:(AtCoder,动态规划)