首先你这个类名看着就不合适,避免Java关键字和保留字行不,虽然编译可以通过,但是这样很容易出一些奇奇怪怪的问题的
for循环这个,光有个分号,没初始化状态
JAVA的a+b
import java.util.Scanner;
public class Main {
public static void main(String[] args)
{
Scanner in = new Scanner(System.in);
int a = in.nextInt();
int b = in.nextInt();
System.out.println(a + b);
}
(1) 最明显的好处是,学会Java,可以参加Java Challenge :)
事实上,Java 只相当于C++的一个改进版,所有的语法都几乎是C++的,很少有变动.
类名要用Main
像下面这样
import java.io.*;
import java.util.*;
public class Main
public static void main(String args[]) throws Exception
Scanner cin=new Scanner(System.in);
int a=cin.nextInt(),b=cin.nextInt();
System.out.println(a+b);
ACM 对输出 要求很严格的, 范例 虽然你编译通过了,可是 提交后它用的数据不一定是这个,你要对 输入输入判断 的够准确!比如 a,b 都要大于0等等.
通过这个代码跑个100什么的就能找到规律:
这个规律找到了就很简单了吧.O(N)都不到.
#includeiostream
#includeunistd.h
#includevector
using?namespace?std;
void?work(bool**?a,int?i,?int?j)//剩余i+1个,最多取j+1个
if(j=i)
a[i][j]=true;
else?for(int?t=1;t=j+1;++t)
a[i][j]=true;return;
a[i][j]=false;
int?main()
int?N;
scanf("%d",N);
bool*?a[N];
for(int?i=0;iN;++i)a[i]=new?bool[i];
for(int?i=1;iN;++i)for(int?j=0;ji;++j)
work(a,i,j);
//printf("a[%d][%d]:%d\n",i+1,j+1,(int)a[i][j]);
先说一下Java对于ACM的一些优点吧:
(1) 对于熟悉C/C++的程序员来说Java 并不难学,两周时间基本可以搞定一般的编程,再用些时间了解一下Java库就行了.Java的语法和C++非常类似,可以说是C++的升级版,只是更加强调面向对象思想而已.(个人见解...)
***小技巧:某些题目用Java超时的话可以用Java打表然后用C/C++提交
关于ACM中应用的一些问题:
代码如下:
import java.io.* import java.util.*
public static void main(String args[])
Scanner cin = new Scanner(new BufferedInputStream(System.in));
也可以直接 Scanner cin = new Scanner(System.in); 加Buffer可能会快一些.
读一个字符串: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(...);
判断是否有下一个输入可以用 cin.hasNext() 或 cin.hasNextInt() 或 cin.hasNextDouble()
System.out.println(n); // n 为 int 型 同一行输出多个整数可以用
System.out.println(new Integer(n).toString() + " " + new Integer(m).toString());
//也可重新定义:
static PrintWriter cout = new PrintWriter(new BufferedOutputStream(System.out));
cout.println(n);
import java.text.*;
DecimalFormat f = new DecimalFormat("#.00#");
DecimalFormat g = new DecimalFormat("0.000");
System.out.println(f.format(a));
System.out.println(f.format(b));
System.out.println(g.format(b));
大数:
BigInteger 和 BigDecimal 是在java.math包中已有的类,前者表示整数,后者表示浮点数
import java.math.* // 需要引入 java.math 包
BigInteger a = BigInteger.valueOf(100);
BigInteger c = a.add(b) // c = a + b;
//主要有以下方法可以使用:
BigInteger add(BigInteger other)
BigInteger subtract(BigInteger other)
BigInteger multiply(BigInteger other)
BigInteger mod(BigInteger other)
int compareTo(BigInteger other)
static BigInteger valueOf(long x)
//输出数字时直接使用 System.out.println(a) 即可
字符串:
String 类用来存储字符串,可以用charAt方法来取出其中某一字节,计数从0开始:
String a = "Hello"; // a.charAt(1) = 'e'
用substring方法可得到子串,如上例
字符串连接可以直接用 + 号,如
String a = "Hello";
String b = "world";
System.out.println(a + ", " + b + "!"); // output "Hello, world!"
如想直接将字符串中的某字节改变,可以使用另外的StringBuffer类.
调用递归(或其他动态方法)
在主类中 main 方法必须是 public static void 的,在 main 中调用非static类时会有警告信息,
可以先建立对象,然后通过对象调用方法:
void dfs(int a)
if () return;
dfs(a+1);
Main e = new Main();
e.dfs(0);
其他注意的事项:
(1) Java 是面向对象的语言,思考方法需要变换一下,里面的函数统称为方法,不要搞错.
数组定义后必须初始化,如 int[] a = new int[100];
Arrays.fill()
Arrays.sort()
Arrays.binarySearch()
虽然Java功能很强大,但不能完全依赖他,毕竟C和C++还是ACM/ICPC的主流语言,适当地使用才能有效提高比赛中的成绩...
附:
例题:POJ 1001
①.import java.io.*;
①.0
①.1 BigDecimal num;
以上就是土嘎嘎小编为大家整理的acm提交java代码相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!