zoukankan      html  css  js  c++  java
  • Floyd+限制路径步数(快速幂优化)

    POJ 3613 Cow Relays
    这里写图片描述

    最短路可以采用Floyd来计算,但是限制时间在1s内,估计直接写会超时,所以要用到快速幂来优化。
    快速幂的思想是:xy=xy/22 所以每次划分下去寻找最短路
    (其实我也没完全想清楚,就不讲太清楚了,怕讲错)

    //STATUS:C++_AC_125MS_1204KB
    #include<stdio.h>
    #include<stdlib.h>
    #include<string.h>
    #include<math.h>
    #include<iostream>
    #include<string>
    #include<algorithm>
    #include<vector>
    #include<queue>
    #include<stack>
    using namespace std;
    #define LL __int64
    #define pii pair<int,int>
    #define Max(a,b) ((a)>(b)?(a):(b))
    #define Min(a,b) ((a)<(b)?(a):(b))
    #define mem(a,b) memset(a,b,sizeof(a))
    #define lson l,mid,rt<<1
    #define rson mid+1,r,rt<<1|1
    const int N=210,M=1000000,INF=0x3f3f3f3f,MOD=1999997;
    const LL LLNF=0x3f3f3f3f3f3f3f3fLL;
    const double DNF=100000000;
    
    int f[N*10],w[N][N];
    int nt,n,m,s,t;
    struct Matrix{
        int ma[N][N];
        Matrix friend operator * (const Matrix a,const Matrix b){
            Matrix ret;
            mem(ret.ma,0x3f);
            int i,j,k;
            for(k=0;k<n;k++)
                for(i=0;i<n;i++)
                    for(j=0;j<n;j++)
                        if(a.ma[i][k]+b.ma[k][j]<ret.ma[i][j])
                            ret.ma[i][j]=a.ma[i][k]+b.ma[k][j];
            return ret;
        }
    }mta,mtb;
    
    int pow(int k)
    {
        mem(mtb.ma,0x3f);
        for(int i=0;i<n;i++)mtb.ma[i][i]=0;
        while(k){
            if(k&1)mtb=mtb*mta;
            mta=mta*mta;
            k>>=1;
        }
        return mtb.ma[f[s]][f[t]];
    }
    
    int main()
    {
     //   freopen("in.txt","r",stdin);
        int i,a,b,c;
        while(~scanf("%d%d%d%d",&nt,&m,&s,&t))
        {
            n=0;
            mem(f,-1);
            mem(mta.ma,0x3f);
            for(i=0;i<m;i++){
                scanf("%d%d%d",&c,&a,&b);
                if(f[a]==-1)f[a]=n++;
                if(f[b]==-1)f[b]=n++;
                mta.ma[f[a]][f[b]]=mta.ma[f[b]][f[a]]=Min(mta.ma[f[a]][f[b]],c);
            }
    
            printf("%d
    ",pow(nt));
        }
        return 0;
    }
    
  • 相关阅读:
    Java Lambda 表达式 对 Map 对象排序
    比较两个list对象是否相同
    ubuntu redis 自启动配置文件(关机有密码)
    spring中订阅redis键值过期消息通知
    网站架构之性能优化(转)
    Json转Java Bean
    spring mvc 4 校验
    java @ResponseBody返回值中去掉NULL字段
    合并两个java bean对象非空属性(泛型)
    spring mvc 删除返回字符串中值为null的字段
  • 原文地址:https://www.cnblogs.com/bryce1010/p/9386942.html
Copyright © 2011-2022 走看看