hdu1757_A Simple Math Problem(新手)
时间:2019-01-11
本文章向大家介绍hdu1757_A Simple Math Problem(新手),主要包括hdu1757_A Simple Math Problem(新手)使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
我使用的是矩阵快速幂的方法写的这一道题目
可以根据题目构造一个第一行为十个输入,后面九行除了对角线下方的斜线是1,其他全为0的矩阵
如果输入 k < 10,那么直接输出k值,如果输入 k >= 10,那么输出是构造的矩阵的k - 9次幂得到的矩阵第一行与(9,8,7,6,5,4,3,2,1,0)的转置相乘后得出的值
然后上代码:
#include<iostream>
using namespace std;
long long p, q;
int* mult(int *a,int *b,int x = 10,int y = 10,int z = 10) //返回值为矩阵x行z列的a*b,其中a是x行y列,b是y行z列
{
int *ans = new int[100];
long long t;
for (int i = 0; i < 100; i++)
ans[i] = 0;
for (int i = 0; i < x; i++)
{
for (int j = 0; j < z; j++)
{
for (int k = 0; k < y; k++)
{
t = ((a[i*y + k] % q) * (b[k*z + j] % q)) % q;
ans[i*z + j] = (ans[i*z + j] + t % q) % q;
}
}
}
return ans;
}
int* pow(int *ans,int *res) //矩阵快速幂
{
while (p)
{
if (p & 1)
{
ans = mult(ans, res);
}
res = mult(res, res);
p = p >> 1;
}
return ans;
}
int main()
{
int res[100], *ans, *t;
while (scanf("%lld %d", &p, &q) != EOF)
{
/**********初始化,构造矩阵************/
ans = new int[100];
t = new int[10];
for (int i = 0; i < 10; i++)
{
t[i] = 9 - i;
for (int j = 0; j < 10; j++)
{
if (i == j)
ans[10 * i + j] = 1;
else
ans[i * 10 + j] = 0;
if (i == j + 1)
res[i * 10 + j] = 1;
else
res[i * 10 + j] = 0;
}
}
for (int i = 0; i < 10; i++)
scanf("%d", &res[i]);
/***********判断数值,决定输出************/
if (p < 10)
cout << p << endl;
else
{
int sum = 0;
p -= 9;
ans = pow(ans, res);
for (int i = 0; i < 10; i++)
{
sum = (sum + (9 - i)*ans[i] % q) % q;
}
cout << sum << endl;
}
}
}
- 工信部:网络强国建设2018年重点工作任务
- 刚刚!张小龙再出重磅!微信小程序掀起新零售红利狂潮!
- 无人驾驶系列——深度学习笔记:Tensorflow的安装-windows系统
- 2018年12大顶级云安全威胁
- 缤果盒子为域名意识打call 六位数秒下bingobox.com
- 用Qt写软件系列二:QCookieViewer(浏览器Cookie查看器)
- 用Qt写软件系列一:QCacheViewer(浏览器缓存查看器)
- 用Qt写软件系列三:一个简单的系统工具(上)
- ChartDirector应用笔记(三)
- 汇编语言 手记9
- 程序员一年写百万行代码是什么体验?这肯定是个Bug
- ChartDirector应用笔记(二)
- ChartDirector应用笔记(一)
- DB Cache
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- localStorage中怎么存对象?
- vue中sessionStorage的使用
- 别再问我 Python 怎么识别数字验证码了!
- Java 多线程设计模式 —— Single Threaded Execution
- SAP Spartacus默认的baseSite是从源代码什么地方读取的
- SAP Spartacus CmsPage的加载逻辑
- JUnit 5 测试 Spring 引擎的时候提示 junit-vintage 错误
- SAP Spartacus activeBaseSite的设置逻辑
- SAP Spartacus取语言设置的入口程序
- 几行 Python 代码实现文字识别,你敢信?
- SAP Spartacus的navigation初始化
- 大数据ETL实践探索 ---- 笔试面试考点
- jQuery 效果
- jQuery 样式操作
- Nginx 限制资源的访问