免费注册 查看新帖 |

Chinaunix

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

[Linux] shell编程写一个判断一个数是不是素数(也就是质数) [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-12-29 18:01 |只看该作者 |倒序浏览
先读取一个数 read  num ;然后就循环进行判断,可是不太会写循环里面的句子,shell是刚接触,不是特别了解,希望大神能给个借鉴。谢谢了

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
2 [报告]
发表于 2013-12-30 10:07 |只看该作者
  1. #!/bin/bash

  2. while read num;do
  3.     if [[ ! $num =~ ^[0-9]*$ ]];then
  4.         echo "input integer please"
  5.         continue
  6.     fi
  7.     n=`echo ${num}%2 | bc`
  8.     if [ $n -eq 1 ];then
  9.         echo "$num is prime"
  10.     else
  11.         echo "$num is not prime"
  12.     fi
  13. done
复制代码

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
3 [报告]
发表于 2013-12-30 10:21 |只看该作者
回复 2# linux_c_py_php


    质数是只有 1 和它自身两个正除数的数,例如 2, 3, 5, 7 等;而不是能否被 2 整除。

论坛徽章:
0
4 [报告]
发表于 2013-12-30 10:27 |只看该作者
本帖最后由 syre 于 2013-12-30 10:31 编辑

有个factor命令

$ factor 510549076672471
510549076672471: 510549076672471

$ factor 510549076672472
510549076672472: 2 2 2 3061087 20848357

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
5 [报告]
发表于 2013-12-30 11:38 |只看该作者
回复 4# syre


找出小于 100 的素数:

  1. for n in `seq 1 100`; do factor $n | awk '{ if (NF == 2) print $2 }' ; done
复制代码

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
6 [报告]
发表于 2013-12-30 11:41 |只看该作者
回复 2# linux_c_py_php


    使用 bc 判断一个整数是否为素数:

  1. define isprime (n) {
  2.         auto f;

  3.         if (n < 2) return 0;

  4.         for ( f = 2; f <= sqrt(n); f++)
  5.                 if (n % f == 0) return 0;
  6.         return 1;
  7. }
复制代码
使用上述函数找出小于100的素数:

  1. #!/bin/bash

  2. for n in `seq 1 100`; do
  3.         b=$(echo "isprime($n)" | bc isPrime.bc)
  4.         if [ $b -eq 1 ]; then
  5.                 echo $n
  6.         fi
  7. done
复制代码

论坛徽章:
0
7 [报告]
发表于 2013-12-31 00:00 |只看该作者
MMMIX 发表于 2013-12-30 10:21
回复 2# linux_c_py_php


说的对。。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP