辗转相除法

大纲:

  1. 问题
  2. 原理
  3. 反思

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.     反思

  1. 以后我是否还会碰到这种——实现不难,可不知其原理,就无法解题,的题目

        -          打算抽空刷经典算法(math)题

  2.我的同学是怎么在不懂原理的情况下解题的

        -          方向对了,用了模,r!=0神猜测,后面调试把m=n试出来了

  3.若是我尝试用模做,是否也能做出这题,所以它给我的教训是?

        -          有一定可能。遇题先广搜一波,然后对每个可能的点(方向)进行部分深搜

辗转相除法求H.C.F小结的更多相关文章

  1. C实现辗转相除法求两个数的最大公约数

    什么是辗转相除法? 辗转相除法(又名欧几里德算法),它主要用于求两个正整数的最大公约数.是已知的最古老的算法. 用辗转相除法求132和72的最大公约数的步骤: 132 / 72 = 1 ... 60 ...

  2. [LeetCode] H-Index 求H指数

    Given an array of citations (each citation is a non-negative integer) of a researcher, write a funct ...

  3. 辗转相除法求最大公约数,非goto

    #include<iostream> using namespace std; //不推荐用goto,当然用它更快 //辗转相除法求两数的最大公约数 int gcd(long int a, ...

  4. [洛谷P1029]最大公约数与最小公倍数问题 题解(辗转相除法求GCD)

    [洛谷P1029]最大公约数与最小公倍数问题 Description 输入二个正整数x0,y0(2<=x0<100000,2<=y0<=1000000),求出满足下列条件的P, ...

  5. [CodePlus 2017 11月赛]晨跑 题解(辗转相除法求GCD)

    [CodePlus 2017 11月赛]晨跑 Description "无体育,不清华"."每天锻炼一小时,健康工作五十年,幸福生活一辈子".在清华,体育运动绝 ...

  6. 使用辗转相除法求两个数的最大公因数(python实现)

    数学背景: 整除的定义: 任给两个整数a,b,其中b≠0,如果存在一个整数q使得等式                                        a = bq 成立,我们就说是b整除 ...

  7. C语言辗转相除法求2个数的最小公约数

    辗转相除法最大的用途就是用来求两个数的最大公约数. 用(a,b)来表示a和b的最大公约数. 有定理: 已知a,b,c为正整数,若a除以b余c,则(a,b)=(b,c). (证明过程请参考其它资料) 例 ...

  8. 算法:辗转相除法求最大公约数(C语言实现)

    辗转相除法,一种求最大公约数的算法 已知:A / B = C ······ R  (A.B.C.R皆是整数) 假设:D是A的余数,D也是B的余数,那么D就是A和B的公约数 D是A和B的约数,则A和B是 ...

  9. [LeetCode] H-Index II 求H指数之二

    Follow up for H-Index: What if the citations array is sorted in ascending order? Could you optimize ...

随机推荐

  1. 判断div是否有滚动条

    判断div是否有滚动条 var obj=document.getElementById("showDiv"); if(obj.scrollHeight>obj.clientH ...

  2. netcat工具的使用

    用途:网络管理工具. 可以读,写TCP或UDP 网络连接.简写为:nc 常见参数: -h  帮助信息 -l 坚挺模式 -n 指定IP地址 -p 指定端口号 -v 详细输出 1 客户端:很容易建立一个客 ...

  3. Jcompress: 一款基于huffman编码和最小堆的压缩、解压缩小程序

    前言 最近基于huffman编码和最小堆排序算法实现了一个压缩.解压缩的小程序.其源代码已经上传到github上面: Jcompress下载地址 .在本人的github上面有一个叫Utility的re ...

  4. Android几行代码实现实时监听微信聊天

    实现效果: 实时监听当前聊天页面的最新一条消息,如图:            实现原理: 同样是利用AccessibilityService辅助服务,关于这个服务类还不了解的同学可以先看下我上一篇关于 ...

  5. iOS核心笔记—源代码管理工具-GIT

    源代码管理工具-GIT 一. git 概述 1. git 简介? 什么是git? > git是一款开源的分布式版本控制工具 > 在世界上所有的分布式版本控制工具中,git是最快.最简单.最 ...

  6. Ubuntu 制作U盘启动盘

    部门需要一台Linux系统远程共享服务器,需要一个启动盘安装.但是由于公司windows 系统都安装了保安软件,而且软件的使用也是有限制的.所以不能使用UltraISO 这类软件制作U盘启动盘.还好部 ...

  7. java_XML_JAXB

    JAXB 可以实现Java对象与XML的相互转换,在JAXB中,将一个Java对象转换为XML的过程称之为Marshal,将XML转换为Java对象的过程称之为UnMarshal. 下面使用的是JDK ...

  8. java打包jar,war,ear包的作用、区别

    java的打包jar,war,ear包的作用,区别,打包方式. a) 作用与区别      i.    jar: 通常是开发时要引用通用(JAVA)类,打成包便于存放管理      ii.   war ...

  9. python中文编码问题深入分析(一):字符编码基础

    背景:笔者作为一名刚接触python语言的新手,在实际的项目中,遇到过一些中文编码问题,初次遇到这些问题的时候,刚开始显得有些手足无措,也不知从何查起.常言道:有问题,找度娘!当我打开www.baid ...

  10. PLSQL程序流程

    IF语句结构: if(条件表达式)- -then- -执行语句;- -end; IF-THEN-ELSE语句结构: if(条件表达式)- -then- -执行语句;- -else- -执行语句;- e ...