2019牛客多校第五场 B(十进制矩阵快速幂)

传送门

题目就是求一个大指数幂矩阵快速幂的第 n n n

普通的二进制矩阵快速幂无法在给定的时间内跑完,所以将它转换成十进制的(涨姿势了!)

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = 1e6+5;
char n[maxn];
ll Mod;
ll x0,x1,a,b;
int len;
struct matrix{
    ll a[3][3]; //begin with 1
    friend matrix operator*(matrix A,matrix B)
    {
        matrix C;
        C.a[0][0] = C.a[0][1] = C.a[1][0] = C.a[1][1] = 0;
        for(int i=0;i<2;i++){
            for(int j=0;j<2;j++){
            	C.a[i][j]=0;
                for(int k=0;k<2;k++){
                    C.a[i][j]=(C.a[i][j]+A.a[i][k]*B.a[k][j])%Mod;
                }
            }
        }
        return C;
    }
};
 
 
matrix qpow(matrix A,int m)//方阵A的m次幂
{
    matrix ans;
    ans.a[0][1] = ans.a[1][0] = 0;
    for(int i=0;i<2;i++) ans.a[i][i]=1; //单位矩阵
    while(m)
    {
        if(m&1) ans=ans*A;
        A=A*A;
        m>>=1;
    }
    return ans;
}

matrix ppow(matrix x,char *b){
    len = strlen(b);
    matrix ans;
    ans.a[0][0] = x1,ans.a[0][1] = x0;
    int sub = 0;
    for(int i = len-1; i >= 0; i--){
    	int m = b[i]-'0';
		if(!sub){
			if(m > 0){
				m--;
				sub = 1;
			}
			else if(m == 0) m = 9;
		}
        if(m > 0){
            matrix tmp = qpow(x,m);
            ans = ans*tmp;
        }
        x = qpow(x,10);
    }
    return ans;
}


int main(){
    scanf("%lld%lld%lld%lld",&x0,&x1,&a,&b);
    scanf("%s%lld",n,&Mod);
    matrix f;
    
    //sub(n,one,mm);
    f.a[0][0] = a; f.a[0][1] = 1; f.a[1][0] = b; f.a[1][1] = 0;
    matrix ans = ppow(f,n);
    printf("%lld\n",ans.a[0][0]%Mod);
}
/*
1 1 1 1
1 1000007
*/
基于可靠性评估序贯蒙特卡洛模拟法的配电网可靠性评估研究(Matlab代码实现)内容概要:本文围绕“基于可靠性评估序贯蒙特卡洛模拟法的配电网可靠性评估研究”,介绍了利用Matlab代码实现配电网可靠性的仿真分析方法。重点采用序贯蒙特卡洛模拟法对配电网进行长时间段的状态抽样与统计,通过模拟系统元件的故障与修复过程,评估配电网的关键可靠性指标,如系统停电频率、停电持续时间、负荷点可靠性等。该方法能够有效处理复杂网络结构与设备时序特性,提升评估精度,适用于含分布式电源、电动汽车等新型负荷接入的现代配电网。文中提供了完整的Matlab实现代码与案例分析,便于复现和扩展应用。; 适合人群:具备电力系统基础知识和Matlab编程能力的高研究生、科研人员及电力行业技术人员,尤其适合从事配电网规划、运行与可靠性分析相关工作的人员; 使用场景及目标:①掌握序贯蒙特卡洛模拟法在电力系统可靠性评估中的基本原理与实现流程;②学习如何通过Matlab构建配电网仿真模型并进行状态转移模拟;③应用于含新能源接入的复杂配电网可靠性定量评估与优化设计; 阅读建议:建议结合文中提供的Matlab代码逐段调试运行,理解状态抽样、故障判断、修复逻辑及指标统计的具体实现方式,同时可扩展至不同网络结构或加入更不确定性因素进行深化研究。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值