【题目链接】

  http://acm.hdu.edu.cn/showproblem.php?pid=6719


在本题中,我们只有两种方法计算两个的矩阵的乘积,第一种为定义法,需要次乘法和次加法。第二种为Strassen分治法,仅当为偶数时可以使用,需要次加法以及再计算次大小为的矩阵的乘积。这次更小矩阵的乘积也可以选择两种方法之一计算。现假设计算机计算一次加法需要单位时间,计算一次乘法需要单位时间,其他任何操作不花费时间,问计算两个的矩阵的乘积至少需要多少时间。输出答案模的余数。

定义法: A * n * n * (n-1) + B * n * n * n

Strassen:A * ( n / 2 ) * ( n / 2 ) * ( n - 1 ) +  7 * Min (定义法(n/2),Strassen(n/2))

C++

 #include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll mod = 1e9+;
ll A,B,x;
ll Matrix_Mul( ll n ){
n %= mod ;
ll t1 = B * n % mod * n % mod * n % mod ;
ll t2 = A * n % mod * n % mod * (n-) % mod ;
return ( t1%mod + t2%mod + mod ) % mod ;
} ll Strassen( ll n ){
if( n& )
return Matrix_Mul(n); if( n <= * A / (A+B) )
return Matrix_Mul(n); ll Half_n = n / ;
ll t1 = 18ll * Half_n % mod * Half_n % mod * A % mod ;
ll t2 = 7ll * Strassen( Half_n ) % mod ;
return ( t1 + t2 + mod ) % mod ;
}
int main()
{
ios_base :: sync_with_stdio(false);
cin.tie(NULL) , cout.tie(NULL) ; int T;
cin >> T ;
while( T-- ){
cin >> x >> A >> B ;
cout << Strassen(x) << endl;
}
return ;
}

Java

 import java.math.* ;
import java.util.*;
import java.security.MessageDigest;
public class Main{ static BigInteger Zero = new BigInteger ("");
static BigInteger One = new BigInteger ("");
static BigInteger Two = new BigInteger ("") ;
static BigInteger Four = new BigInteger ("") ;
static BigInteger Seven = new BigInteger ("");
static BigInteger Eighteen = new BigInteger ("") ;
static BigInteger Mod = new BigInteger(""); static BigInteger Martirx_Mul( BigInteger n , BigInteger a , BigInteger b ){
BigInteger Step1 = n.multiply(n).multiply(n).multiply(b) ;
BigInteger Step2 = n.subtract(One).multiply(n).multiply(n).multiply(a) ;
BigInteger Ans = Step1.add(Step2);
return Ans;
} static BigInteger Strassen( BigInteger x , BigInteger a , BigInteger b ){ if( x.equals(One) )
return Martirx_Mul( One , a , b ); BigInteger Half_x = x.divide(Two);
BigInteger Step1 = Eighteen.multiply( Half_x ).multiply(Half_x).multiply( a );
BigInteger Step2 = Seven.multiply( Strassen( Half_x , a ,b ).min(Martirx_Mul(Half_x,a,b)) ) ;
BigInteger Mul = Step1.add(Step2);
return Mul.min( Martirx_Mul(x,a,b) );
} public static void main( String[] args ){
Scanner cin = new Scanner(System.in);
int T = cin.nextInt();
while( T -- > ){
BigInteger a,b,n; n=cin.nextBigInteger();
a=cin.nextBigInteger();
b=cin.nextBigInteger();
BigInteger ans=Strassen(n,a,b).mod(Mod);
System.out.println(ans);
}
} }

【百度之星2019】Strassen的更多相关文章

  1. 百度之星2019第一场1002 Game

    思路: 离散化之后dp,dp[i][j]表示完成前i个任务并且处在第j个点所需要的最小代价. 实现: #include <bits/stdc++.h> using namespace st ...

  2. 百度之星 2019 预赛三 A 最短路 1

    题目链接 分析 异或运算满足「三角不等式」. $\forall a, b, c \in \mathbb{Z}_{\ge 0}$,有 $a \xor b \le (a \xor c) + (c \xor ...

  3. 2019 年百度之星·程序设计大赛 - 初赛四 1001 Strassen

    比赛链接:2019 年百度之星·程序设计大赛 - 初赛四 题目链接:HDU-6719 Strassen C++ 没写出来 于是直接上 Java 暴力. 好像可以用 __int128. import j ...

  4. 2019 年百度之星·程序设计大赛 - 初赛一 C. HDU 6670 Mindis 离散化+dijkstra

    题目链接 :http://acm.hdu.edu.cn/showproblem.php?pid=6670 Mindis Time Limit: 4000/2000 MS (Java/Others) M ...

  5. 2019 年百度之星·程序设计大赛 - 初赛一Game HDU 6669 (实现,贪心)

    Game Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submissi ...

  6. 2019 年百度之星 初赛一 1002 Game

    传送门 Problem Description 度度熊在玩一个好玩的游戏.游戏的主人公站在一根数轴上,他可以在数轴上任意移动,对于每次移动,他可以选择往左或往右走一格或两格.现在他要依次完成 n 个任 ...

  7. 2016百度之星 初赛2A ABEF

    只做了1001 1002 1005 1006.剩下2题可能以后补? http://acm.hdu.edu.cn/search.php?field=problem&key=2016%22%B0% ...

  8. 2016百度之星 资格赛ABCDE

    看题:http://bestcoder.hdu.edu.cn/contests/contest_show.php?cid=690 交题:http://acm.hdu.edu.cn/search.php ...

  9. HDU 5690:2016"百度之星" - 初赛 All X

    原文链接:https://www.dreamwings.cn/hdu5690/2657.html All X Time Limit: 2000/1000 MS (Java/Others)    Mem ...

随机推荐

  1. 什么是vue的全家桶

    vue.js有著名的全家桶系列,包含了vue-router,vuex, vue-resource,再加上构建工具vue-cli,就是一个完整的vue项目的核心构成.

  2. bzoj2406 矩阵

    我们不妨想一想,这道题目又有\(abs\)又有\(Max\)不是很好算对吧. 所以我们二分答案,考虑怎么\(check\). 对于一个点,显然它能够取的范围是\([l,r]\),接着是对于一行一列都有 ...

  3. Java 8:掌握 Lambda 表达式

    本文将介绍 Java 8 新增的 Lambda 表达式,包括 Lambda 表达式的常见用法以及方法引用的用法,并对 Lambda 表达式的原理进行分析,最后对 Lambda 表达式的优缺点进行一个总 ...

  4. java关于Integer设置-128到127的静态缓存

    今天在一个java群里,看到有个群友问到如下为什么第一个为true,第二个为false. System.out.println(Integer.valueOf("50")==Int ...

  5. combobox放入数据

    页面 <th width="15%">国际分类号</th><td  width="30%"> <select  cla ...

  6. checkbox取反

    var qxs = document.getElementsByName("qx"); for(var i=0;i<qxs.length;i++){   var e=qxs[ ...

  7. Java 关于日期加一天(日期往后多一天)

    1.原来Java的日期添加不像.NET的.Add: import java.util.Date ; Date date=new   Date();//取时间System.out.println(dat ...

  8. css让文字竖着排列 writing-mode 属性

    writing-mode 属性 writing-mode 属性定义了文本在水平或垂直方向上如何排布. 语法格式如下: writing-mode: horizontal-tb | vertical-rl ...

  9. echarts3.0之关系图详解

    近期需要使用echarts关系图,当我打开echarts3.0官方demo后发现,对于新手而言,直接看懂有点儿难度,固写这样一篇文章让自己加深记忆,也便新手迅速上手.话不多说,开整生气! echart ...

  10. python 了解一下__dict__

    写在前面 这几天在写关于描述器的博客,在了解描述器的机制的时候,翻了很多博客里面都提到了__dict__, 我想更多的了解一点描述器的机制,所以我得先弄清楚这个__dict__到底是干啥的. 计算机语 ...