免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1570 | 回复: 4
打印 上一主题 下一主题

[数值计算] 求助~最大公约数随意赋值的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-01-07 15:24 |只看该作者 |倒序浏览
图中 红框部分,
为什么这种算法是对的呢?我人工推出来就是不对
假设1
  dividend=10
  divisor=20
until里面的运算步骤为
  remainder=10 % 20 =0
  dividend=20
明显不对呀?


  1. #!/bin/bash

  2. ARGS=2
  3. E_BADARGS=65

  4. if [ $# -ne "$ARGS" ]
  5. then
  6.   echo "Usage: `basename $0` first-number second-number"
  7.   exit $E_BADARGS
  8. fi

  9. gcd ()
  10. {
  11.   dividend=$1
  12.   divisor=$2

  13.   remainder=1

  14.   until [ "$remainder" -eq 0 ]
  15.   do
  16.     let "remainder = $dividend % $divisor"
  17.     dividend=$divisor
  18.     divisor=$remainder
  19.   done
  20. }

  21. gcd $1 $2

  22. echo; echo "GCD of $1 and $2 = $dividend"; echo

  23. exit 0
复制代码

论坛徽章:
7
申猴
日期:2014-12-21 13:57:24巳蛇
日期:2014-12-25 22:27:08申猴
日期:2015-01-19 08:07:36辰龙
日期:2015-02-04 11:40:06处女座
日期:2015-02-04 11:40:412015年亚洲杯之卡塔尔
日期:2015-03-06 12:01:322015年亚洲杯之乌兹别克斯坦
日期:2015-03-31 13:43:57
2 [报告]
发表于 2015-01-07 15:32 |只看该作者
  1. remainder=10 % 20 =0
复制代码
这块你怎么得出来的?

论坛徽章:
0
3 [报告]
发表于 2015-01-07 15:33 |只看该作者
回复 2# goofool
这是在求余呀?
没对?
   

论坛徽章:
0
4 [报告]
发表于 2015-01-07 15:40 |只看该作者
回复 2# goofool

刚刚去查了下。。商0余10…… 囧了。。

   

论坛徽章:
5
未羊
日期:2014-08-04 16:15:21天秤座
日期:2014-08-13 13:52:372015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:112015亚冠之浦和红钻
日期:2015-06-29 15:30:48
5 [报告]
发表于 2015-01-07 16:06 |只看该作者
有个shell命令叫factor
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP