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的标准只规定特定数据类型需要实现的最小长度,特 ...
随机推荐
- 导入贴图操作:处理贴图MaxSize和Format
using UnityEngine; using System.Collections; using UnityEditor; public class ImportModflyTextures : ...
- C++ template —— 类型区分(十一)
前面的博文介绍了模板的基础,深入模板特性,模板和设计的一些内容.从这篇开始,我们介绍一些高级模板设计,开发某些相对较小.并且互相独立的功能,而且对于这些简单功能而言,模板是最好的实现方法:(1)一个用 ...
- STL——仿函数(函数对象)
一.仿函数(也叫函数对象)概观 仿函数的作用主要在哪里?从第6章可以看出,STL所提供的各种算法,往往有两个版本,其中一个版本表现出最常用(或最直观)的某种运算,第二个版本则表现出最泛化的演算流程,允 ...
- C语言EOF是什么?
C语言 EOF是什么? Linux中,在新的一行的开头,按下Ctrl-D,就代表EOF(如果在一行的中间按下Ctrl-D,则表示输出"标准输入"的缓存区,所以这时必须按两次Ctrl ...
- OpenCV——识别各省份地图轮廓
好久没有发OpenCV的博客了,最近想到了一个识别地图轮廓的方案,就写来试试.(识别中国的28个省份地图轮廓,不考虑直辖市) 首先,我的基本思路是 用最小的矩形将地图的轮廓圈出来,可以根据长方形的长 ...
- 【小程序+ thinkphp5】 获取微信运动数据
配置.请参看上篇文章.这里直接上代码 PHP 代码: //获取微信运动数据: public function test(){ $code = input("code"); $sig ...
- jquery.peity.js简介
jQuery简单图表peity.js <html xmlns="http://www.w3.org/1999/xhtml"> <head> <titl ...
- 日记整理---->2016-11-25
2017-03-02开始,记录的一些知识点.岁月长,三更漏.漫漫回廊,依稀人空瘦.借酒消愁入断肠,倚剑笑我,我独自寻殇. 一.vx中的v-bind和{{}}的区别 <td class=" ...
- win7 默认程序设置
1. . 2. 3. 4. 双击某个程序-->选择浏览 目标程序 .即可完成
- -bash: locate: command not found
部分版本的linux系统使用locate快速查找某文件路径会报以下错误: -bash: locate: command not found 其原因是没有安装mlocate这个包 安装:yum -y ...