A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 七弦 中级黑马   /  2014-5-26 20:48  /  6319 人查看  /  39 人回复  /   4 人收藏 转载请遵从CC协议 禁止商业使用本文

在网上看到一道题,听说是曾经微软出的题,暂时没看出来头绪。。


写一个程序实现:输入一个数,求它的阶乘后面有多少个连续的0,将其连续0 的个数输出。

可能有同学不知道阶乘,简单说一下:例如所要求的数是n,则阶乘式是1×2×3×……×n,设得到的积是x,x就是n的阶乘
能写出来的上来秀秀!

评分

参与人数 1技术分 +1 收起 理由
李小然 + 1 赞一个!

查看全部评分

39 个回复

倒序浏览
  1. import java.util.regex.Matcher;
  2. import java.util.regex.Pattern;
  3. /**
  4. * 输入一个数,求它的阶乘后面有多少个连续的0,将其连续0 的个数输出。
  5.        例如所要求的数是n,则阶乘式是1×2×3×……×n,设得到的积是x,x就是n的阶乘。
  6.        分析:阶乘容易求出,将阶乘转成字符串,判断尾部是否有0.
  7.        设置一个正则表达式,将其取出即可
  8. * @author Administrator
  9. *
  10. */
  11. public class JieCheng {

  12.         public static void main(String[] args) {
  13.                 // TODO Auto-generated method stub
  14.                 getEndZero(20);
  15.         }
  16.         public static void getEndZero(int x ){
  17.                 int b = 1;
  18.                 //long b = 1; 没测试过
  19.                 for(int a=1;a<=x;a++){
  20.                         b = b*a;
  21.                 }
  22.                 //b这里定义的int类型,貌似给的数过大的话
  23.                 //其阶乘就超出int的取值范围,b就为负数了,考虑用long类型
  24.                 //x的值超过16就为负数了
  25.                 System.out.println("阶乘:"+b);
  26.                 String str = b+"";
  27.                 //System.out.println(str);
  28.                 String reg = "0+$";
  29.                 if(str.endsWith("0")){
  30.                         Pattern p = Pattern.compile(reg);
  31.                         Matcher m = p.matcher(str);
  32.                         while(m.find()){
  33.                                 System.out.println(m.group());
  34.                                 System.out.println("后面0的个数:"+(m.end()-m.start()));
  35.                         }
  36.                 }else{
  37.                         System.out.println(-1);
  38.                 }
  39.         }
  40. }
复制代码


看看这个代码可行不?

评分

参与人数 1技术分 +1 收起 理由
李小然 + 1 赞一个!

查看全部评分

回复 使用道具 举报
个人建议楼上用BigInteger
回复 使用道具 举报
本帖最后由 西门吹风 于 2014-5-27 09:11 编辑

今天刚好看完for循环视频,尝试用for循环写了一下,这个数好像不能太大,不然超过long的范围,望高人指正
  1. /*
  2. 1、任意数先分为0和非0
  3. 2、非0时用for循环求阶乘积,分为正数、负数
  4. 3、用阶乘积与10取模看其余数是否为0,如果是则计数器加1,
  5. 然后用阶乘积除以10,相当于最后一个0去掉,再与10取模,
  6. 如此循环,直到去掉N个0后的阶乘积与10取模的余数不为0时
  7. 跳出循环。
  8. */
  9. class CountZero
  10. {
  11.         public static void main(String[] args)
  12.         {
  13.                 int x=15;      
  14.                 long sum=1l;      
  15.                 int count=0;           
  16.                 if(x!=0)                     
  17.                 {
  18.                         if(x>0)                     
  19.                         {
  20.                                 for(int i=1;i<=x;i++)        
  21.                                 {
  22.                                         sum=sum*i;
  23.                                 }
  24.                         }
  25.                         else if(x<0)            
  26.                         {
  27.                                 for(int i=-1;i>=x;i--)   
  28.                                 {
  29.                                         sum=sum*i;
  30.                                 }
  31.                         }
  32.                         for(long i=sum ;i%10==0 ;i=i/10)      
  33.                         {                                                      
  34.                                 count++;                                    
  35.                         }        
  36.                 }
  37.                 else                                                
  38.                 {
  39.                         count=1;
  40.                         sum=0;
  41.                 }
  42.                 System.out.println(sum);      
  43.                 System.out.println(count);
  44.         }
  45. }
复制代码



评分

参与人数 1技术分 +1 收起 理由
李小然 + 1 很给力!

查看全部评分

回复 使用道具 举报
学习一下。
回复 使用道具 举报
学习一下...谢谢分享...
回复 使用道具 举报
张百振 发表于 2014-5-26 23:43
个人建议楼上用BigInteger

刚刚看了下BigInteger,好像确实更好一些,谢谢。
3楼的想法很好。
回复 使用道具 举报
七弦 中级黑马 2014-5-27 08:06:18
8#
本帖最后由 七弦 于 2014-6-12 19:15 编辑

四楼输入的数超过20貌似就挂了,最多就能求出来4个0
回复 使用道具 举报
七弦 中级黑马 2014-5-27 08:09:57
9#
本帖最后由 七弦 于 2014-6-12 19:13 编辑

都很厉害!!!
回复 使用道具 举报
本帖最后由 七弦 于 2014-6-29 15:02 编辑

三楼的思路很不错,学习了。

回复 使用道具 举报
西门吹风 发表于 2014-5-27 00:29
今天刚好看完for循环视频,尝试用for循环写了一下,这个数好像不能太大,不然超过long的范围,望高人指正

...

写的很好
回复 使用道具 举报
本帖最后由 七弦 于 2014-6-29 14:59 编辑

21的阶乘已经超过了long的最大
回复 使用道具 举报
只需要求出包含几个2和5,还有几个10的倍数就轻松搞定了不是?想一下,阶乘里只要乘以10,最后肯定多一个0,还有只要包含一个2和5这一对数,就又会多一个0,哈哈哈,多么简单呀,我现在时间太紧了,正在准备面试,要不然就代码写出来了
回复 使用道具 举报
张百振 发表于 2014-5-26 23:43
个人建议楼上用BigInteger

如果超出了BigInteger呢?这个要想真的很好的解决,我觉得还是要先转化为字符转来解决,毕竟字符串的长度要大于数值型。
回复 使用道具 举报
vampire.007 发表于 2014-5-27 13:00
如果超出了BigInteger呢?这个要想真的很好的解决,我觉得还是要先转化为字符转来解决,毕竟字符串的长度 ...

你想多了吧?10000的阶乘BigInteger都没问题,你还想用String?
回复 使用道具 举报
本帖最后由 pk49800 于 2014-5-28 14:10 编辑
  1. public class ComputeZero {
  2.        
  3.         <p style="line-height: 30px; text-indent: 2em;">public static void main(String[] args){
  4.                 int count = 0;//末尾0的個數
  5.                 int i = 16;//被計算的數,如果太大則需要將計算結果擴充範圍
  6.                 Long sum = 1L;//計算結果
  7.                 while(i!=0){
  8.                         sum = sum*i;
  9.                         i--;
  10.                 }
  11.                 System.out.println(i+"的階乘為:"+sum);
  12.                
  13.                 while(sum%5==0){
  14.                         sum = sum/5;
  15.                         count++;
  16.                 }
  17.                
  18.                 System.out.println("末尾包含:"+count+"個0");
  19.                
  20.         }</p>

  21. }
复制代码

這個是求階乘末尾的0,如果階乘分解因式之後包含的N個10(2*5這種也算在內),那這個階乘結果的末尾0就有N個

回复 使用道具 举报
这个题不能硬做乘法啊,发这个大家看懂就会做啦
  1. /**
  2. * 需求:求1到1000乘积的0的个数
  3. * 思路:假设乘积结果是。。。。。000000000,每一个0就相当于乘与10,1到1000的乘积可以等同于将1到1000这些数字完全分解成质数再相乘
  4. * 1=        1*1
  5. * 2=        1*2
  6. * 3=        1*3
  7. * 4=        2*2
  8. * 5=        1*5
  9. * 6=        2*3
  10. * 。
  11. * 。
  12. * 10=        2*5
  13. * 11=        1*11
  14. * 12=        2*3*4
  15. * .
  16. * .
  17. * 15=        3*5
  18. * .
  19. * .
  20. * 20=        2*2*5
  21. * 。
  22. *
  23. * 25=        5*5。
  24. *
  25. * 1000=        2*2*2*5*5*5
  26. * 就是将上面的等号右边的所有数乘起来。我们知道乘积中出现一个10,就会多一个0.而10=2*5,只有2和5乘积才能等于10,其他所有的数的乘积都不等于10。
  27. * 不要说10*20也会有0,要知道我们已经将这些数字完全分解成了质数,所以只要求出上面等号右边能构造成多少个(2*5),明显可以看出2的个数多于5,所以
  28. * 我们只要求出5的个数就是(2*5)的个数,也就是乘积中10的个数,也就是要求的0的个数。
  29. * 怎么求5的个数,楼主的程序我也没看懂。不过我自己想了一种,大家看一下。
  30. * 1.首先只要5的倍数,分解的质数里才会包含5,即
  31. * 5 =        1*5
  32. * 10=        2*5
  33. * 15=         3*5
  34. * 20=        4*5
  35. * .    .
  36. * .        .
  37. * 1000=200*5
  38. * 上面的等号右边我们直观的可以看到已经有200个5,再求1到200分解成5的倍数
  39. *  5 =        1*5
  40. * 10=        2*5
  41. * 15=         3*5
  42. * 20=        4*5
  43. * .    .
  44. * .        .
  45. * 200=        40*5
  46. * 上面上面又有40个5,再求出1到40分解成5的倍数
  47. *  5 =        1*5
  48. * 10=        2*5
  49. * 15=         3*5
  50. * 20=        4*5
  51. * 。
  52. * 40=        8*5
  53. * 上面有8个5,再求1到8分解成5的倍数
  54. * 5=        1*5
  55. * 上面就1个5
  56. * 所以5的个数=200+40+8+1=249
  57. * 步骤:
  58. *
  59. * @author lhy
  60. *
  61. */
  62. public class Test8
  63. {
  64.         public static void main(String[] args)
  65.         {
  66.                 int num=0;//创建变量记录5的个数
  67.                 int z=1000;
  68.                
  69.                 while(z>=5){
  70.                         num = z/5 +num;//第一次是200,第二次是40,第三次是8,其实都是除于5得到的
  71.                         z = z/5;
  72.                 }
  73.                         System.out.print(num);
  74.         }
  75. }
复制代码
回复 使用道具 举报 2 0
好难啊!!!!!!!
回复 使用道具 举报
学习了!
回复 使用道具 举报
本帖最后由 七弦 于 2014-6-29 15:02 编辑

。。。。。。。。。。。。
回复 使用道具 举报
12下一页
您需要登录后才可以回帖 登录 | 加入黑马