【题目链接】

  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. Git git rm和git rm --cached

    git rm 和 git rm --cached 的区别 git rm file git commit -m "xxx" git push origin master 删除本地及仓 ...

  2. Java 面向对象(三)

    封装 什么是封装 面向对象三大特征之一 1. 把对象的状态和行为看成一个统一的整体,将字段和方法放到一个类中. 2. 信息隐藏:把不需要让外界知道的信息隐藏起来.尽可能隐藏对象功能实现细节,向外界暴露 ...

  3. easyUI的datagrid表格的使用

    实现easyUI表格的里面数据的增删改查功能.SQL使用Oracle和mybatis. 话不多说,直接上代码. 首先是前段部分的. var session = GetSession(); var pa ...

  4. openjudge计算概论-大整数加法

    /*=====================================================================1004:大整数加法总时间限制: 1000ms 内存限制: ...

  5. Java体系

    Java之父:詹姆斯·高斯林 java之前叫做“Oak”,后改名为Java.//Oak来源于橡树,java 来源爪哇岛的一种咖啡 Java语言平台 J2SE(Java 2 Platform Stand ...

  6. c# 扫描局域网IP列表的几种方法

    很多软件都有获知局域网在线计算机IP的功能,但是在.net怎么实现呢,有好多方法, 下面我给大家介绍几种,供大家参考. 1.微软社区上介绍了使用Active Directory 来遍历局域网 利用Di ...

  7. 002-创建型-01-工厂方法模式(Factory Method)

    一.概述 定义一个创建对象的接口,但让实现这个接口的类来决定实例化那个类,工厂方法让类的实例化推迟到子类中进行. 工厂方法模式(FACTORY METHOD)同样属于一种常用的对象创建型设计模式,又称 ...

  8. IfcSlab

    // IfcRoot ----------------------------------------------------------- // attributes: // shared_ptr& ...

  9. LeetCode_88. Merge Sorted Array

    88. Merge Sorted Array Easy Given two sorted integer arrays nums1 and nums2, merge nums2 into nums1  ...

  10. (八)Centos之文件搜索命令locate

    一.文件搜索命令locate locate优点是 搜索速度快 ,缺点是只能按文件名搜索: 1.1 新建一个文件   1.2 更新数据库 locate命令搜索的是 /var/lib/mlocate 下的 ...