筆試中java的輸入輸出


一,輸入

import java.util.*;
import java.io.*;

public class Main {
    public static void main(String[] args) {
        Scanner cin1 = new Scanner(System.in);
        Scanner cin2 = new Scanner(new BufferedInputStream(System.in));
    }
}

具體方法

讀一個整數: int n = sc.nextInt(); 
讀一個字符串:String s = sc.next(); 
讀一個浮點數:double t = sc.nextDouble(); 
讀一整行: String s = sc.nextLine(); 
判斷是否有下一個輸入
sc.hasNext()
sc.hasNextInt()
sc.hasNextDouble()
sc.hasNextLine()

二,輸出

2.1 標准輸出

System.out.print(); 
System.out.println(); 
System.out.format();
System.out.printf();

2.2 格式化輸出

//0指一位數字,#指除0以外的數字(如果是0,則不顯示)
    DecimalFormat fd = new DecimalFormat("#.00#");
    DecimalFormat gd = new DecimalFormat("0.000");
    System.out.println("x =" + fd.format(x));
    System.out.println("x =" + gd.format(x));

三,其他操作

3.1 高精度運算

涉及到兩個類BigDecimal(表示浮點數)和BigInteger(表示整數) 
使用這兩個類的時候需要加上import java.math.*;

(1)valueOf(parament); 將參數轉換為指定類型
(2)add(); //大數加法
(3)substract(); //減法
(4)multiply(); //乘法
(5)divided(); //相除取整
(6)remainder(); //取余
(7)pow(); //a.pow(b) = a ^ b
(8)gcd(); //最大公約數
(9)abs(); //絕對值
(10)negate(); //取反數
(11)mod(); //a.mod(b) = a % b = a.remainder(b)
(12)max(); min();
(13)public int compareTo(); //比較
(14)boolean equals(); //比較是否相等
int a = 1, b =3, c = 10;  

BigInteger x, y, z, ans;  

x = BigInteger.valueOf(a); y = BigInteger.valueOf(b); z = BigInteger.valueOf(c);  

ans = x.add(y); System.out.println(ans);  

ans = z.divide(y); System.out.println(ans);  

ans = x.mod(z); System.out.println(ans);

3.2 提高讀寫速度

使用StreamTokenizer 和 PrintWriter

public class Main {
    public static void main(String[] args) throws IOException {
        int a, b;
        StreamTokenizer in = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
        PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));

        while (in.nextToken() != StreamTokenizer.TT_EOF)
        // in.nextToken()讀下一個標記,StreamTokenizer.TT_EOF是個參數EOF
        {
            a = (int) in.nval;
            in.nextToken();
            b = (int) in.nval;
            out.println(a + b);
        }
        out.flush();// 刷新緩沖區,否則a+b會留在緩沖區
    }
}

3.3 排序

intArray = new int[] { 4, 1, 3, -23 }; 
Arrays.sort(intArray); 

忽略大小寫排序 Case-insensitive sort
Arrays.sort(strArray, String.CASE_INSENSITIVE_ORDER); 

反向排序, Reverse-order sort 
Arrays.sort(strArray, Collections.reverseOrder()); 

自定義容器排序的兩種方法 

方法一:讓對象類實現comparable接口,覆寫compareTo函數,里面用你說的私有數據來比較大小

class xxx implements Comparable{  
 @Override  
    public int compareTo(Object o) {  
       //your way
    } 
} 

方法二:新建一個Comparator對象

Comparator comparator=new Comparator<T>() {
    @Override
    public int compare(T o1, T o2) {
        // TODO Auto-generated method stub
        return 0;
    }
};
//then
Collections.sort(s,new Comparator);  

3.4 進制轉換

String st = Integer.toString(num, base); // 把num當做10進制的數轉成base進制的st(base <= 35).

int num = Integer.parseInt(st, base); // 把st當做base進制,轉成10進制的int(parseInt有兩個參數,第一個為要轉的字符串,第二個為說明是什么進制).  

BigInter m = new BigInteger(st, base); // st是字符串,base是st的進制.

System.out.println("十進制10轉16進制為"+Integer.toHexString(10));
System.out.println("十進制10轉二進制為"+Integer.toBinaryString(10));

3.5 四舍五入

System.out.println("2.5的四舍五入值:" + Math.round(12.5));
System.out.println("-2.5的四舍五入值:" + Math.round(-12.5));
System.out.println("舍掉小數取整:Math.floor(-2.5)=" + (int)Math.floor(-i)); 
System.out.println("湊整:Math.ceil(-2.5)=" + (int)Math.ceil(-i)); 

BigDecimal i = num.setScale(2,RoundingMode.HALF_EVEN); 

1、 ROUND_UP:遠離零方向舍入。向絕對值最大的方向舍入,只要舍棄位非0即進位。
2、 ROUND_DOWN:趨向零方向舍入。向絕對值最小的方向輸入,所有的位都要舍棄,不存在進位情況。
3、 ROUND_CEILING:向正無窮方向舍入。向正最大方向靠攏。若是正數,舍入行為類似於ROUND_UP,      若為負數,舍入行為類似於ROUND_DOWN。Math.round()方法就是使用的此模式。
4、 ROUND_FLOOR:向負無窮方向舍入。向負無窮方向靠攏。若是正數,舍入行為類似於ROUND_DOWN;若為負數,舍入行為類似於ROUND_UP。
5、 HALF_UP:最近數字舍入(5進)。這是我們最經典的四舍五入。
6、 HALF_DOWN:最近數字舍入(5舍)。在這里5是要舍棄的。
7、 HAIL_EVEN:銀行家舍入法。

 

4,問題:Java中nextInt()后接nextLine()讀取不到數據

在使用Scanner對象的nextLine()函數讀取輸入的一行數據時,有時會出現讀取不到數據的情況。如下圖:

 

  這是因為在調用nextLine()函數前調用了Scanner的另一個函數nextInt()(或是nextDouble())。

  出現這種情況的原因是兩個函數的處理機制不同,nextInt()函數在緩沖區中遇到“空格”、“回車符”等空白字符時會將空白字符前的數據讀取走,但空白字符不會被處理掉,而nextLine()函數是在緩沖區中讀取一行數據,這行數據以“回車符”為結束標志,nextLine()會把包括回車符在內的數據提走。所以nextInt()后的nextLine()函數並非讀取不到數據,因為nextInt()將“回車符”留在了緩沖區,nextLine()讀取時遇到的第一個字符便是“回車符”,所以直接結束了。

解決方法: 

1.在要使用nextLine()前先調用一次nextLine(),這樣留在緩沖區的“回車符”就會被處理掉,這時第二個nextLine()函數可以正常讀取到數據。 

2.避免在nextLine()之前調用nextInt()等函數,可以統一使用nextLine()來讀取數據,之后再進行類型轉換。

 

轉自:

https://blog.csdn.net/qiao1245/article/details/53020417

https://blog.csdn.net/u014584274/article/details/75089058

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM