zoukankan      html  css  js  c++  java
  • bzoj 2751 快速幂

    首先我们知道,对于所有种情况,我们可以将每一位可以放的

    数的值加起来,所有位置的乘起来,等于的就是最后的答案,具体

    为什么正确,可以根据乘法分配律来想一想。

    那么对于所有不做要求的,快速幂直接算就行了,然后快排下,就知道

    每个位置不放那些值,减掉后乘进去就行了。

    /**************************************************************
        Problem: 2751
        User: BLADEVIL
        Language: Pascal
        Result: Accepted
        Time:344 ms
        Memory:1008 kb
    ****************************************************************/
     
    //By BLADEVIL
    const
        d39                                 =1000000007;
         
    var
        n, m, k                             :longint;
        a, b                                :array[0..100010] of longint;
        ans                                 :int64;
         
    procedure swap(var a,b:longint);
    var
        c                                   :longint;
    begin
        c:=a; a:=b; b:=c;
    end;
         
    procedure qs(low,high:longint);
    var
        i, j, xx, yy                        :longint;
    begin
        i:=low; j:=high; 
        xx:=a[(i+j) div 2]; yy:=b[(i+j) div 2];
        while i<j do
        begin
            while (a[i]<xx) or (a[i]=xx) and (b[i]<yy) do inc(i);
            while (a[j]>xx) or (a[j]=xx) and (b[j]>yy) do dec(j);
            if i<=j then
            begin
                swap(a[i],a[j]);
                swap(b[i],b[j]);
                inc(i); dec(j);
            end;
        end;
        if i<high then qs(i,high);
        if j>low then qs(low,j);
    end;
         
    procedure init;
    var
        i                                   :longint;
    begin
        read(n,m,k);
        for i:=1 to k do read(a[i],b[i]);
        qs(1,k);
    end;
     
    function mi(a,b:int64):int64;
    var
        sum                                 :int64;
    begin
        sum:=a;
        mi:=1;
        while b<>0 do
        begin
            if b mod 2=1 then mi:=mi*sum mod d39;
            sum:=sum*sum mod d39;
            b:=b div 2;
        end;
    end;
     
    procedure main;
    var
        i                                   :longint;
        sum, x, y, z                        :int64;
    begin
        sum:=m;
        x:=-1;
        for i:=1 to k do
        begin
            if a[i]<>x then
            begin
                dec(sum);
                x:=a[i];
            end;
        end;
        x:=n; y:=n+1;
        if x mod 2=0 then x:=x div 2 else y:=y div 2;
        x:=x mod d39;
        y:=y mod d39;
        x:=x*y mod d39;
        ans:=mi(x,sum);
        for i:=1 to k do if (a[i]=a[i-1]) and (b[i]=b[i-1]) then b[i-1]:=0;
        y:=-1;
        z:=-1;
        for i:=1 to k do
        begin
            if a[i]<>y then
            begin
                if i<>1 then ans:=ans*z mod d39;
                z:=x;
                y:=a[i];
                z:=((x-b[i]) mod d39+d39) mod d39;
            end else z:=((z-b[i])mod d39+d39) mod d39;
        end;
        if z<>-1 then ans:=ans*z mod d39;
        writeln(ans);
    end;
         
     
    begin
        init;
        main;
    end.
  • 相关阅读:
    bug-- java.lang.RuntimeException: Type “Klass*"
    ThreadPoolExecutor源码分析二
    ThreadPoolExecutor源码分析一
    java动态代理框架
    liunx 中一个命令可以检测 ps -C java --no-heading| wc -l 一般用于shell脚步编写用
    log4j.properties 使用说明
    图文详解MyEclipse中新建Maven webapp项目的步骤(很详细)
    MySQL高可用性之Keepalived+Mysql(双主热备)
    使用cglib动态创建类,添加方法
    2017年5月5日 星红桉liunx动手实践mysql 主主双机热备
  • 原文地址:https://www.cnblogs.com/BLADEVIL/p/3491366.html
Copyright © 2011-2022 走看看