【百度之星2019】Strassen
【题目链接】
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的更多相关文章
- 百度之星2019第一场1002 Game
思路: 离散化之后dp,dp[i][j]表示完成前i个任务并且处在第j个点所需要的最小代价. 实现: #include <bits/stdc++.h> using namespace st ...
- 百度之星 2019 预赛三 A 最短路 1
题目链接 分析 异或运算满足「三角不等式」. $\forall a, b, c \in \mathbb{Z}_{\ge 0}$,有 $a \xor b \le (a \xor c) + (c \xor ...
- 2019 年百度之星·程序设计大赛 - 初赛四 1001 Strassen
比赛链接:2019 年百度之星·程序设计大赛 - 初赛四 题目链接:HDU-6719 Strassen C++ 没写出来 于是直接上 Java 暴力. 好像可以用 __int128. import j ...
- 2019 年百度之星·程序设计大赛 - 初赛一 C. HDU 6670 Mindis 离散化+dijkstra
题目链接 :http://acm.hdu.edu.cn/showproblem.php?pid=6670 Mindis Time Limit: 4000/2000 MS (Java/Others) M ...
- 2019 年百度之星·程序设计大赛 - 初赛一Game HDU 6669 (实现,贪心)
Game Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submissi ...
- 2019 年百度之星 初赛一 1002 Game
传送门 Problem Description 度度熊在玩一个好玩的游戏.游戏的主人公站在一根数轴上,他可以在数轴上任意移动,对于每次移动,他可以选择往左或往右走一格或两格.现在他要依次完成 n 个任 ...
- 2016百度之星 初赛2A ABEF
只做了1001 1002 1005 1006.剩下2题可能以后补? http://acm.hdu.edu.cn/search.php?field=problem&key=2016%22%B0% ...
- 2016百度之星 资格赛ABCDE
看题:http://bestcoder.hdu.edu.cn/contests/contest_show.php?cid=690 交题:http://acm.hdu.edu.cn/search.php ...
- HDU 5690:2016"百度之星" - 初赛 All X
原文链接:https://www.dreamwings.cn/hdu5690/2657.html All X Time Limit: 2000/1000 MS (Java/Others) Mem ...
随机推荐
- vue怎么将一个组件引入另一个组件?
项目是由的vue-cli搭建 1.这里有两个组件,需求是把newComponents.vue里面的东西引入到helloWorld里面 2.index.js里面的配置 3.newComponents里面 ...
- ArrayUtils.
String sfck=mp.get("SFCK")==null?"":mp.get("SFCK").toString(); Str ...
- CentOS 7 安装MySQL8
安装 下载Linux对应的MySQL https://dev.mysql.com/downloads/mysql/ CentOS选择Red Hat Enterprise Linux 在/usr/loc ...
- SpringBoot-自动装配对象及源码ImportSelector分析
SpringBoot框架已经很流行了,笔者做项目也一直在用,使用久了,越来越觉得有必要理解SpringBoot框架中的一些原理了,目前的面试几乎都会用问到底层原理.我们在使用过程中基本上是搭建有一个框 ...
- vue实现滚动条滚到相应高度触发动画的操作
一.vue项目引入animate.css 第一步:在命令行中执行: npm install animate.css --save 第二步:引入及使用: main.js中: import animate ...
- sql数据库为null时候ASP语句判断问题
我有一个表test1,有字段num,字段num有null值,也有空值,也有其他值,我要用asp语句判断我查询出来的num的值是否为null值.应该怎么写 严谨一点,要有两层判断: If IsNull( ...
- React vs. Angular vs. Vue
原文连接 历史 React是一个用于构建Web应用程序UI组件的JavaScript库. React由Facebook维护,许多领先的科技品牌在其开发环境中使用React. React被Faceboo ...
- Block pool ID needed, but service not yet registered with NN java.lang.Exception: trace 异常解决
以上为报错信息: 原因大概为:dd和nd关联的versionId不同导致, 解决方案,备份之前的current文件夹,让其自己生成新的.
- mysql删除某一个数据库中所有的表
SELECT concat('DROP TABLE IF EXISTS ', table_name, ';') FROM information_schema.tables WHERE table_s ...
- win7下安装IIS7
在Windows 7下如何安装IIS7,以及IIS7在安装过程中的一些需要注意的设置,以及在IIS7下配置ASP的正确方法. 在Windows 7下面IIS7的安装方法: 一.进入Windows 7的 ...