Java兩種方法計算出階乘尾部連續0的個數
第一個方法是計算出階乘然後計算字符串的0的個數。
import java.util.Scanner; import java.math.BigDecimal; import java.text.DecimalFormat; public class jc{ public static void main(String args[]){ Scanner reader = new Scanner(System.in); DecimalFormat a = new DecimalFormat("#"); int num; num = reader.nextInt(); double sum=1; for(int i=2;i<=num;i++){ sum*=i; } //System.out.println(sum); //System.out.println(cal_the_number_of_zero(sum+"")); System.out.println(a.format(sum)); System.out.println(cal_the_number_of_zero(a.format(sum))); } public static int cal_the_number_of_zero(String str){ int num=0; for(int i=0;i<str.length();i++){ if(str.charAt(i)=='0'){ num++; } else{num=0;} } return num; } }
但是當數字很大時,上面那種方法就不能計算出來瞭。於是我們可以利用數學方法來計算。
import java.util.Scanner; public class Main{ public static void main(String[] args){ Scanner sc = new Scanner(System.in); int n = sc.nextInt(); int ret =0; for(int i=n;i>=5;i--){ int tmp =i; while(tmp%5==0){ ret++; tmp=tmp/5; } } System.out.println(ret); } }
https://www.nowcoder.com/questionTerminal/6ffdd7e4197c403e88c6a8aa3e7a332a
到此這篇關於Java兩種方法計算出階乘尾部連續0的個數的文章就介紹到這瞭,更多相關Java 階乘尾部連續0的個數內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Java Scanner的使用和hasNextXXX()的用法說明
- 用java實現猜數字遊戲
- Java中while語句的簡單知識及應用
- java編程學習輸入輸出詳解看完快速上手
- Java基礎語法:邏輯控制