E-小红的序列乘积2.0(牛客周赛55)

E-小红的序列乘积2.0

题意:给定数组a,求子序列前缀积个位数为6的数字个数。

分析:只要算个位数是否为6,所以把a数组都换成个位数上的数就好了。用a数组与1到9的数字进行组合,用组合数学算出组合数。

代码:

复制代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll mod=1e9+7;
ll qpow2(ll a,ll b,ll p){
    ll base=a;
    ll res=1;
    while(b){
            if(b&1)res=(res*base)%p;
            base=(base*base)%p;
            b>>=1;
    }
    return res;
}
​
int main(){
    int n;cin>>n;
    ll a[n+10];ll ans=0;
    ll mp[100],mp2[100];
    for(int i=1;i<=n;i++){
        cin>>a[i];
        a[i]%=10;
    }
    memset(mp,0,sizeof(mp));
    mp[1]=1;
    for(int i=1;i<=n;i++){
        for(int j=1;j<=9;j++)mp2[j]=0;
        for(int j=1;j<=9;j++){
            int c=a[i]*j%10;
            if(c==6){
                ans+=mp[j]*qpow2(2,n-i,mod);
                cout<<i<<" "<<mp[j]<<endl;
                ans%=mod;
            }
            mp2[c]+=mp[j];mp2[c]%=mod;
        }
        for(int j=1;j<=9;j++){
            mp[j]+=mp2[j];mp[j]%=mod;
        }
    }
    cout<<ans<<endl;
    return 0;
}
相关推荐
钱多多先森19 小时前
【Dify】使用 python 调用 Dify 的 API 服务,查看“知识检索”返回内容,用于前端溯源展示
开发语言·前端·python·dify
qq_4171292519 小时前
基于C++的区块链实现
开发语言·c++·算法
霍理迪19 小时前
JS—数组
开发语言·前端·javascript
Ulyanov19 小时前
超越平面:用impress.js打造智能多面棱柱演示器
开发语言·前端·javascript·平面
2401_8324027519 小时前
C++中的命令模式实战
开发语言·c++·算法
有一个好名字19 小时前
力扣-钥匙和房间
算法·leetcode·深度优先
zhougl99619 小时前
Java定时任务实现
java·开发语言·python
水饺编程19 小时前
第4章,[标签 Win32] :系统字体与字符大小
c语言·c++·windows·visual studio
历程里程碑19 小时前
Linux 10:make Makefile自动化编译实战指南及进度条解析
linux·运维·服务器·开发语言·c++·笔记·自动化
zhougl99619 小时前
继承成员变量和继承方法的区别
java·开发语言