CH0102 64位整数乘法 数论
正解:数论/一个神仙想法
解题报告:
先放传送门qwq
两种方法,都还挺妙的就都写了qwq
第一种是快速幂
把b用二进制表示成,ck*2k+ck-1*2k-1+...+c0*20
然后就可以表示成,a*(ck*2k+ck-1*2k-1+...+c0*20)%p
然后就可以用快速幂的思想做掉,能理解趴?
哦其实也可以用秦九韶理解,差不多,反正都这个意思就是了qwq
#include<bits/stdc++.h> using namespace std; #define rp(i,x,y) for(register ll i=x;i<=y;++i) #define ll unsigned long long ll a,b,p; inline ll read() { ;; '))ch=getchar(); ; )+(x<<)+(ch^'),ch=getchar(); return y?x:-x; } inline ll js(ll x,ll y,ll mod) { ll ans=; while(x) { )ans+=y,ans%=mod; x>>=;y<<=;y%=mod; } return ans; } int main() { a=read(),b=read(),p=read(); printf("%lld\n",js(a,b,p)); ; }
第二种是一个,神仙想法
首先很容易能理解就是 a*b%p=a*b-⌊a*b/p⌋*p
然后就可以分成俩部分计算,一个是a*b直接算一个是⌊a*b/p⌋*p
首先理解一个东西,就是因为%p所以答案一定是小于等于p的,那么溢出导致舍弃掉了的部分就没有关系反正本来就是太大了要被废掉的
然后另一个就是⌊a*b/p⌋*p,我们可以先开个double算出⌊a*b/p⌋,考虑精度不够怎么办?没有关系因为double有效数字就是18-19的样子(,,,就是这么巧,被出题人安排得明明白白×)所以舍弃掉的部分刚好就是我们不需要的部分
然后就欧克了
是不是很妙!!!
(然后我开始做的时候还WA了一下,,,解释下发生了什么qwq就是,a和b是要%p的然后我忘了,,,所以就WA了,估计是溢出之类的问题?虽然我本机是A的?真实哭泣QAQ
#include<bits/stdc++.h> using namespace std; #define rp(i,x,y) for(register ll i=x;i<=y;++i) #define ll unsigned long long ll a,b,p,cjk; double goldgenius; inline ll read() { ;; '))ch=getchar(); ; )+(x<<)+(ch^'),ch=getchar(); return y?x:-x; } int main() { a=read(),b=read(),p=read(); cjk=a*b;goldgenius=(double)a*b/p; cjk=cjk-(ll)goldgenius*p;cjk%=p;)cjk+=p; printf("%lld\n",cjk); ; }
umm然后留下一个傻逼问题(,,,其实开始困扰了我半天来着×),这样的
为什么不可以直接算a*b%p呢?
这是因为!可能你舍掉了高位之后膜p会有问题!能懂趴?然后用法二就可以巧妙避免这个问题!
好那这题就解决辣!
CH0102 64位整数乘法 数论的更多相关文章
- CH0101 a^b、 CH0102 64位整数乘法(快速幂、快速乘)【模板题】
题目链接:传送门 //a^b 传送门 //64位整数乘法 题目: 描述 求 a 的 b 次方对 p 取模的值,其中 ≤a,b,p≤^ 输入格式 三个用空格隔开的整数a,b和p. 输出格 ...
- CH0101 a^b & CH0102 64位整数乘法
大数取模的两道题. 虐狗宝典学习笔记: 两个数值执行算术运算时,以参与运算的最高数值类型为基准,与保存结果的变量类型无关.两个32位整数的成绩可能超过int类型的表示范围,但是CPU只会用一个32位寄 ...
- CH 0101 - a^b / CH 0102 - 64位整数乘法 - [快速幂和快速乘]
0101 a^b 题目链接:传送门 描述 求 a 的 b 次方对 p 取模的值,其中 1≤a,b,p≤10^9 输入格式 三个用空格隔开的整数 a,b 和 p. 输出格式 一个整数,表示 a^b mo ...
- AcWing 90. 64位整数乘法
求a*b%p的值. 0<a,b,p<1e18; 原题链接 #include<bits/stdc++.h> #define ull unsigned long long usin ...
- C++的64位整数
在做ACM题时,经常都会遇到一些比较大的整数.而常用的内置整数类型常常显得太小了:其中long 和 int 范围是[-2^31,2^31),即-2147483648~2147483647.而unsig ...
- C/C++中的64位整数
C/C++中的64位整数(__int64 and long long) 在做ACM题时,经常都会遇到一些比较大的整数.而常用的内置整数类型常常显得太小了:其中long 和 int 范围是[-2^31, ...
- windows 64位整数
#include <iostream> #include <ctime> using namespace std; int main() { cout << cou ...
- printf如何输出64位整数
From: http://blog.csdn.net/zzqhost/article/details/6064886 关于printf函数输出64位数的问题,其实在window下和linux下是不一样 ...
- C对64位整数类型的支持
在使用C语言过程中可能需要接触长整数类型,其中包括固定长度数据类型的声明.输入输出函数的标志符等细节,在此记录. int64_t 与 uint64_t C的标准只规定特定数据类型需要实现的最小长度,特 ...
随机推荐
- [XPath] XPath 与 lxml (四)XPath 运算符
XPath 中支持的运算符 # | 或: 返回所有 price 和 title 节点集合 >>> root.xpath('//price|//title') [<Element ...
- MQTT_DEMO
1 /* 2 Copyright (c) 2009-2012 Roger Light <roger@atchoo.org> 3 All rights reserved. 4 5 Redis ...
- Spring Mvc 页面传递数组到后台接收
1.定义一个简单的类 User.java public class User { private Integer id; private String name; public Integer get ...
- Java EE发展史
前言 最近的这段时间一直在学习Java EE,刚刚完成了从0到1的蜕变,所以顺便整理一下我所了解到的Java EE,给刚入门学习的新人一些头绪,而所谓“启示录”,就是这个意思. 一.Java EE是什 ...
- 关于bat中使用rar压缩命令
数据库备份,导出的dmp 文件比较大,需要压缩,压缩后大小能变为原来十分之一左右吧. 写的是批处理的语句,每天调用,自动导出dmp 文件,压缩删除原文件. 首先写下路径 先将压缩软件的路径写入系统的环 ...
- 数据流-------C#文件和byte[]互换问题
今天使用FileInfo.CopyTo的时候出现问题,当然并不是使用的问题,而是一些细节. 不过报错的时候,一度让我认为,copyto这个方法,给的参数必须是文件夹,而不是文件.所以就有了下面的查找 ...
- System.Web.Mvc.AJAX缺少程序集引用
今天在构建新项目的时候,出现这个错误,实际上这个出现过很多次了,但是每次都忘记之前怎么解决的,之前博客也不记得写过没有...
- [sql异常]SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的
//执行远程数据库表查询 SELECT * FROM OPENDATASOURCE('SQLOLEDB', 'Data Source=数据库地址;User ID=sa;password=sa' ).n ...
- 大智慧F10离线资料压缩包带F10关键字过滤软件--更新于2014-01-06.rar 184MB
大智慧F10离线资料包带F10关键字过滤软件--更新于2014-01-06.rar 移步到百度网盘下载: http://pan.baidu.com/s/1c01PDnE
- Elasticsearch学习之快速入门案例
1. document数据格式 面向文档的搜索分析引擎 (1)应用系统的数据结构都是面向对象的,复杂的(2)对象数据存储到数据库中,只能拆解开来,变为扁平的多张表,每次查询的时候还得还原回对象格式,相 ...