zoukankan      html  css  js  c++  java
  • java题目练手

    大数阶乘

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=28

    代码如下:

    [java] view plaincopy
     
    1. import java.io.*;  
    2. import java.math.BigInteger;  
    3. import java.util.*;  
    4.   
    5. public class Main  
    6. {  
    7.     public static void main(String args[])  
    8.     {  
    9.         Scanner cin = new Scanner(System.in);     
    10.         int n = cin.nextInt();  
    11.         BigInteger ans = BigInteger.ONE;  
    12.         for(int i = 1; i <= n; ++i)  
    13.             ans = ans.multiply(BigInteger.valueOf(i));  
    14.         System.out.println(ans);  
    15.     }  
    16. }  

    棋盘覆盖

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=45

    代码如下:

    [java] view plaincopy
     
    1. import java.math.BigInteger;  
    2. import java.util.*;  
    3. import java.io.*;  
    4.   
    5. public class Main  
    6. {  
    7.     public static void main(String args[])  
    8.     {  
    9.         Scanner in = new Scanner(System.in);  
    10.         int test = in.nextInt();  
    11.         while(test-- > 0)  
    12.         {  
    13.             int n;  
    14.             n = in.nextInt();  
    15.             BigInteger a = new BigInteger("4");  
    16.             for(int i = 1; i < n; ++i)  
    17.                 a = a.multiply(BigInteger.valueOf(4));  
    18.             System.out.println(a.subtract(BigInteger.valueOf(1)).divide(BigInteger.valueOf(3)));  
    19.         }  
    20.     }  
    21. }  

    比较大小

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=73

    代码如下:

    [java] view plaincopy
     
    1. import java.io.*;  
    2. import java.math.BigInteger;  
    3. import java.util.*;  
    4.   
    5. public class Main  
    6. {  
    7.     public static void main(String args[])  
    8.     {  
    9.         Scanner cin = new Scanner(System.in);     
    10.         while(cin.hasNext())  
    11.         {  
    12.             BigInteger a = cin.nextBigInteger();  
    13.             BigInteger b = cin.nextBigInteger();  
    14.             if(a.equals(BigInteger.ZERO) && b.equals(BigInteger.ZERO))  
    15.                 break;  
    16.             int flag = a.compareTo(b);  
    17.             if(flag == -1)  
    18.                 System.out.println("a<b");  
    19.             else if(flag == 0)  
    20.                 System.out.println("a==b");  
    21.             else  
    22.                 System.out.println("a>b");  
    23.         }  
    24.     }  
    25. }  

    大数加法

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=103

    代码如下:

    [java] view plaincopy
     
    1. import java.math.BigInteger;  
    2. import java.util.*;  
    3. import java.io.*;  
    4.   
    5. public class Main  
    6. {  
    7.     public static void main(String args[])  
    8.     {  
    9.         Scanner in = new Scanner(System.in);  
    10.         int n = in.nextInt();         
    11.         for(int i = 1; i <= n; ++i)  
    12.         {  
    13.             BigInteger a = in.nextBigInteger();  
    14.             BigInteger b = in.nextBigInteger();  
    15.             BigInteger ans = a.add(b);  
    16.             System.out.println("Case " + i + ":");  
    17.             System.out.println(a + " + " + b + " = " +ans);  
    18.         }  
    19.     }  
    20. }  

    递推求值

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=114

    代码如下:

    [java] view plaincopy
     
    1. import java.io.*;  
    2. import java.math.BigInteger;  
    3. import java.util.*;  
    4.   
    5. public class Main  
    6. {  
    7.     public static void main(String args[])  
    8.     {  
    9.         Scanner cin = new Scanner(System.in);     
    10.         BigInteger a[] = new BigInteger[100];  
    11.         while(cin.hasNext())  
    12.         {  
    13.             for(int i = 0; i <= 2; ++i)  
    14.                 a[i] = cin.nextBigInteger();  
    15.             for(int i = 3; i <= 99; ++i)  
    16.                 a[i] = a[i - 1].add(a[i - 2]).add(a[i - 3]);  
    17.             System.out.println(a[99]);  
    18.         }  
    19.     }  
    20. }  

    高精度幂

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=155

    代码如下:

    [java] view plaincopy
     
    1. import java.io.*;  
    2. import java.math.BigDecimal;  
    3. import java.util.*;  
    4.   
    5. public class Main  
    6. {  
    7.     public static void main(String args[])  
    8.     {  
    9.         Scanner cin = new Scanner(System.in);     
    10.         while(cin.hasNext())  
    11.         {  
    12.             BigDecimal ans = cin.nextBigDecimal();  
    13.             int n = cin.nextInt();  
    14.             String res = ans.pow(n).stripTrailingZeros().toPlainString(); //整数去掉小数点和后面的0  
    15.             if(res.startsWith("0")) //去掉前导0  
    16.             {  
    17.                 res = res.substring(1);  
    18.             }  
    19.             System.out.println(res);  
    20.         }  
    21.     }  
    22. }  
  • 相关阅读:
    一个提高N倍系统新能的编程点,却总是被普通开发们遗忘
    工作不到一年,做出了100k系统,老板给我升职加薪
    offer收割机也有方法论
    最长公共前缀
    罗马数字转整数
    回文数
    整数反转
    两数之和
    网页中Office和pdf相关文件导出
    搭建一个低配版的Mock Server
  • 原文地址:https://www.cnblogs.com/chengsheng/p/4702832.html
Copyright © 2011-2022 走看看