zoukankan      html  css  js  c++  java
  • c语言实践:求两个数的最大公约数

    我的思路是这样的:比如12和16这两个数。先理解一下概念,什么叫最大公约数。就是12有很多个因数,16也有很多个因数,这两堆因数中有一些重合的因数,在这些重合的因数中找到那个最大的。那么最大公约数一定是两个数的公约数,且最大公约数一定再12的因数中寻找的。OK,我们先对12求除所有的因数,那么需要一个循环,在这个循环中每次拿到12的一个因数,看它是不是16的一个因数,如果是,那么说明这个因数就是12和16的一个公因数,暂时把最大公约数设置为这个公因数,然后进行下次循环,如果能找到12和16的又一个公因数,那么就把这个公因数设置为最大公约数,直到循环结束,直接输出公因数的值就是最大公约数。

    int main()
    {
       /*
       题目:求两个数的最大公约数
       */
    
    
    
    	
    
    	int a = 0;
    	int b = 0;
    	int i = 1;
    	int great_common_divisor = 1;
    
    	scanf_s("%d %d",&a,&b);
    
    	if (a%b == 0 || b % a == 0)//如果能直接整除,那么较小的那一个就是最大公约数
    	{
    		if (a > b)
    		{
    			printf("greatest common divisor is %d",b);
    		}
    		else
    		{
    			printf("greatest common divisor is %d",a);
    		}
    
    	}
    	else
    	{
    		while(i<=a)
    		{
    			if (a%i == 0)//等于0说明找到了a的一个因数i
    			{
    				if (b%i == 0)//等于0说明找到了a和b的一个公因数
    				{
    					//把这个公因数暂时设置为最大公约数
    					great_common_divisor = i;
    				}
    
    			}
    			i++;
    		}
    		//循环结束之后,最后一次修改的那个公因数就是最大公约数
    		printf("greatest common divisor is %d",great_common_divisor);
    	}
    	
    
    
    
    
    }
    

      

  • 相关阅读:
    asp+access win2008php+mysql /dedecms 配置总结
    js获取页面元素位置函数(跨浏览器)
    Extjs 4 小记
    小总结
    新浪微博 page应用 自适应高度设定 终于找到解决方法
    常用的三层架构设计(转载)
    http://www.jeasyui.com/
    http://j-ui.com/
    日期编辑器MooTools DatePicker
    android布局
  • 原文地址:https://www.cnblogs.com/yfish/p/9629372.html
Copyright © 2011-2022 走看看