【学习笔记】ACM与Java

这两天遇到了一些关于大数据处理的题目,发现Java对于这方面的优势很大。最重要的是代码量小了。于是针对这两天对Java的摸索,写一篇日志。记录一下针对ACM来说常用的Java方面的东西。

1、输入

首先要想输入需要先包括:

import java.util.*; 

 

我们需要其中的 Scanner类声明的对象来扫描控制台输入。

针对A+B来说:

import java.util.*;
public class Main
{
	public static void main(String [] args)
	{
		Scanner cin = new Scanner(System.in);//对于Scanner 类声明对象cin用来扫描控制台输入
		int a = cin.nextInt();
		int b = cin.nextInt();
		System.out.println(a+b);//输出a+b
		cin.close();
	}
}

读一个整数:  int n = cin.nextInt();       相当于 scanf("%d", &n);  或 cin >> n; 

读一个字符串:String s = cin.next();       相当于 scanf("%s", s);   或 cin >> s;  

读一个浮点数:double t = cin.nextDouble(); 相当于 scanf("%lf", &t); 或 cin >> t;  

读一整行:    String s = cin.nextLine();   相当于 gets(s);          或 cin.getline(...); 

读一个大数:  BigInteger c = cin.nextBigInteger();


不过需要注意的是它们没有像scanf一样有判断是否输入到结尾的功能。


这时候需要用一个Scanner类的方法hasnext()来判断是否输入到文件结尾;


例如POJ2506 这是一个针对大数处理的递推题。用Java就很好解决。

import java.math.*;//大数类在Java.math里面,如果不包括的话声明不了大数对象
import java.util.*;

public class Main
{
	public static void main(String[] args)
	{

		// TODO Auto-generated method stub
		/*sss*/
		BigInteger [] a=new BigInteger[255]; //大数数组
		a[0]=BigInteger.ONE; //初始化
		a[1]=BigInteger.ONE;
		a[2]=a[1].add(a[0].add(a[0]));
		for(int i=3;i<=250;i++)
		{
			a[i]=a[i-1].add(a[i-2].add(a[i-2]));
		}
		Scanner cin = new Scanner(System.in); //输入打开
		
		while(cin.hasNext())//判断是否文件结束
		{
			int n=cin.nextInt();
			System.out.println(a[n]); //输出
		}
		cin .close();//输入关闭
	}
} 


2、输出:

public class Main {
	public static void main(String[] args)
	{

		// TODO Auto-generated method stub
		
		double d;
		
		d=9999.99999;
		
		System.out.format("%f",d);                //9999.999990     没有回车
		
		System.out.format("%10.10f",d).println(); //9999.9999900000 输出回车
		
		System.out.format("%.4f",d).println();    //10000.0000      输出回车
		
		System.out.format("%3.4f",d).println();   //10000.0000		输出回车
		
		System.out.println(d);                    //输出当前变量      输出回车
		
		System.out.println();           		  //                输出回车
		
		System.out.printf("%f",d);	   			  //9999.999990     没有回车
		
		System.out.print(d);					  //9999.99999      没有回车
		
	}
}


当然,输出的时候也有对小数位数处理的方法:

0代表当前位向后都是0就输出0占位,#代表若当前位向后都是0就不输出这些位上的数字。

import java.text.DecimalFormat;
public class Main {
	public static void main(String[] args)  {
		double num = 9.999;
		DecimalFormat p3 = new DecimalFormat("#.00#");
		DecimalFormat p4 = new DecimalFormat("#.000#");
		DecimalFormat p5 = new DecimalFormat("#.0000#");
		System.out.println(p3.format(num));//输出9.999
		System.out.println(p4.format(num));//输出9.999
		System.out.println(p5.format(num));//输出9.9990

		
	}
}


3、高精度

对于大数来说,Java提供了BigDecimal和BigInteger两个类,都包含在java.math.*里面。

BigInteger是大整形类,BigDecimal是大浮点型类。

这两个类产生的对象没有数据范围,只要你的电脑内存足够就可以。

下面用BigInteger举个例子:

import java.math.BigInteger;

public class Main {
	
	public static void main(String[] args)
	
	{
		
		int a=6,b=3;
		
		BigInteger x,y,z;
		
		x=BigInteger.valueOf(a); 		   //转化赋值
		
		y=BigInteger.valueOf(b);
		
		System.out.println(x.add(y));      //加
		
		System.out.println(x.subtract(y)); //减
		
		System.out.println(x.multiply(y)); //乘
		
		System.out.println(x.divide(y));   //除
		
		System.out.println(x.mod(y));      //取余
	}
}

4、进制转换

java一直就是作弊器一般的存在,就像它的进制转换函数一样:

public class Main {
	
	public static void main(String[] args)
	
	{
		String string;
		int a=8;
		int x=2;
		string = Integer.toString(a, x);    //把int型数据转换乘X进制数并转换成string型
		System.out.println(string);
		
		int b = Integer.parseInt(string, x);//把字符串当作X进制数转换成int型
		System.out.println(b);
	}
}

5、字符串

Java中的String   和char数组是完全不同的两种东西。

String中的字符是不能在原位置改变的,要改变必须改变并保存到新的String里,或者保存到char 数组里再修改

import java.io.*;
import java.util.*;
public class Main
{
	public static void main(String[] args) 
	{
		Scanner cin = new Scanner (new BufferedInputStream(System.in));
		String st = "abcdefg";
		System.out.println(st.charAt(0)); // st.charAt(i)就相当于st[i].
		char [] ch;
		ch = st.toCharArray(); // 字符串转换为字符数组.
		for (int i = 0; i < ch.length; i++){
			ch[i] += 1;//字符数组可以像C++   一样操作
		}
		System.out.println(ch); // 输入为“bcdefgh”.
		st = st.substring(1); // 则从第1位开始copy(开头为第0位).
		System.out.println(st);
		st=st.substring(2, 4);  //从第2位copy到第4位(不包括第4位)
		System.out.println(st);//输出“de”
	}
}


posted @ 2014-01-26 17:34  、小呆  阅读(146)  评论(0编辑  收藏  举报