辗转相除法求H.C.F小结
辗转相除法
大纲:
- 问题
- 原理
- 反思
1. 问题
一个试题,请完成以下填空
下列程序是利用辗转相除法求H.C.F(最大公约数)
include <stdio.h> int main(){ int m,n,r; scanf(“%d%d”,&m,&n); r=[?]; while([?]){ m=[?];n=r;r=[?]; printf(“h.c.f is %d”,n); return ; }
应试时未想出解
为什么想不出?
首先是不知道什么是辗转相除法,辗转?m除一下,n除一下?翻来?覆去?
然后在想r是不是m*n
开始在纸上演算,发现几对数字中大数模小数可以得到h.c.f,不过又觉得这题用不到模,所以这种方法被我否定了,后面则是尝试用r=m*n,m=r/2,r=n/m;这种交换,不通,空一的初始化与空二的边界值难以确定
空一:相乘?
空二:输出与r对应,可r到哪为止呢?
空三:m走来被改写???wtf???? M? r/n??
空四:r给n了,r要做次改变,r怎么变呢?辗转相除???
总结失败原因
根本原因,不懂辗转相除法的数学原理
数学知识面窄了
次要原因,问了几个同学,其中一个人用试的给试出来了,另一个数学好,知道怎么做,试出来人的说:
空2是看到输出的是r,所以空2写的r!=0(wtf??),还说这题肯定用模做(wtf???为什么能猜这么准)
求其思考过程,说是先填了几个公试,再调试尝试(wtf??)
没搞懂他是怎么试出来的,到下笔时还是不懂他为什么能成功试出来
2. 原理
设这是一个求a,b两数的H.C.F的函数 gcd(a,b);
gcd(a,b);
如果a>b &&a%b!=0
gcd(a,b)===gcd(b,a%b)
请看到这里的同学拿出笔演算一下,用短除法什么的
拓展阅读:其数学证明
下面给出c代码
int gcd(int a,int b){ return a%b==?b:gcd(b,a%b); }
解读,拿a,b中那个大的数,模小的数,看结果是不是零,是零就输出小的
10 与 5的H.C.F就是5
不是零
10 与 8
10%8=2
到此,用余数去替换大数,然后继续//本文重点
递归 gcd(8,2)
得到2
- 特别注意的点 -
用了模的性质巧妙的碰开了先输大的,再输小的,的问题
5 %10=5,10=5,gcd(10,5)
现在,你可以完成大纲一中的问题了吗?
3. 反思
- 以后我是否还会碰到这种——实现不难,可不知其原理,就无法解题,的题目
- 打算抽空刷经典算法(math)题
2.我的同学是怎么在不懂原理的情况下解题的
- 方向对了,用了模,r!=0神猜测,后面调试把m=n试出来了
3.若是我尝试用模做,是否也能做出这题,所以它给我的教训是?
- 有一定可能。遇题先广搜一波,然后对每个可能的点(方向)进行部分深搜
辗转相除法求H.C.F小结的更多相关文章
- C实现辗转相除法求两个数的最大公约数
什么是辗转相除法? 辗转相除法(又名欧几里德算法),它主要用于求两个正整数的最大公约数.是已知的最古老的算法. 用辗转相除法求132和72的最大公约数的步骤: 132 / 72 = 1 ... 60 ...
- [LeetCode] H-Index 求H指数
Given an array of citations (each citation is a non-negative integer) of a researcher, write a funct ...
- 辗转相除法求最大公约数,非goto
#include<iostream> using namespace std; //不推荐用goto,当然用它更快 //辗转相除法求两数的最大公约数 int gcd(long int a, ...
- [洛谷P1029]最大公约数与最小公倍数问题 题解(辗转相除法求GCD)
[洛谷P1029]最大公约数与最小公倍数问题 Description 输入二个正整数x0,y0(2<=x0<100000,2<=y0<=1000000),求出满足下列条件的P, ...
- [CodePlus 2017 11月赛]晨跑 题解(辗转相除法求GCD)
[CodePlus 2017 11月赛]晨跑 Description "无体育,不清华"."每天锻炼一小时,健康工作五十年,幸福生活一辈子".在清华,体育运动绝 ...
- 使用辗转相除法求两个数的最大公因数(python实现)
数学背景: 整除的定义: 任给两个整数a,b,其中b≠0,如果存在一个整数q使得等式 a = bq 成立,我们就说是b整除 ...
- C语言辗转相除法求2个数的最小公约数
辗转相除法最大的用途就是用来求两个数的最大公约数. 用(a,b)来表示a和b的最大公约数. 有定理: 已知a,b,c为正整数,若a除以b余c,则(a,b)=(b,c). (证明过程请参考其它资料) 例 ...
- 算法:辗转相除法求最大公约数(C语言实现)
辗转相除法,一种求最大公约数的算法 已知:A / B = C ······ R (A.B.C.R皆是整数) 假设:D是A的余数,D也是B的余数,那么D就是A和B的公约数 D是A和B的约数,则A和B是 ...
- [LeetCode] H-Index II 求H指数之二
Follow up for H-Index: What if the citations array is sorted in ascending order? Could you optimize ...
随机推荐
- Mac 修改用户名
系统偏好设置 > 用户与群组 > 解锁 > 用户 > 右键 > 高级选项 > 全名
- 使用XML文件定义菜单
Android提供了两种创建菜单的方式,一种是在Java代码中创建,一种使用XML资源文件定义.上面的实例都是在Java代码中创建菜单,在Java代码中创建菜单存在如下不足. 在Java代码中定义菜单 ...
- Java线程:什么是线程
一 基本概念 多任务:同一时刻运行多个程序的能力.每一个任务称为一个线程.可以同时运行一个以上线程的程序称为多线程程序. Java编写程序都运行在在Java虚拟机(JVM)中,在JVM的内部,程序的多 ...
- C的memcpy和strcpy的区别
strcpy是拷贝字符串,以\0为标志结束(即一旦遇到数据值为0的内存地址拷贝过程即停止) strcpy的原型为 char *strcpy(char *dest, const char *src) 而 ...
- HTTP的GET方法模拟
进行GET方法的测试 #telnet[ ]10.1.1.11[ ]80 GET[ ]/[ ]HTTP/1.0 [两个回车] HEAD[]/[]HTTP/1.0[回车回车] http://www.cnb ...
- 创建 OVS vlan101 并部署 instance - 每天5分钟玩转 OpenStack(139)
前面我们创建了 OVS vlan100 并部署了 instance,今天继续创建 vlan101. subnet IP 地址为 172.16.101.0/24. 底层网络发生了什么变化 Neutron ...
- python yield generator 详解
本文将由浅入深详细介绍yield以及generator,包括以下内容:什么generator,生成generator的方法,generator的特点,generator基础及高级应用场景,genera ...
- .net 开发经理的月薪
因为各人的成长不一样,有人工作了5年,技术也只能当个高级程序员,有人工作了两年,就能带领一个团队,有人在初中时期就写了一个很牛X 的框架,而我工作也快5年,也努力奋斗了5年,我觉得自己有能力做开发经理 ...
- 2017年试试Web组件化框架Omi
Open and modern framework for building user interfaces. Omi的Github地址https://github.com/AlloyTeam/omi ...
- asp.net权限认证:OWIN实现OAuth 2.0 之密码模式(Resource Owner Password Credential)
asp.net权限认证系列 asp.net权限认证:Forms认证 asp.net权限认证:HTTP基本认证(http basic) asp.net权限认证:Windows认证 asp.net权限认证 ...