程序设计竞赛java

一、固定代码结构

Java 没有裸写 main 的说法,必须套类,且类名必须是英文大写开头(Eclipse 要求),直接写一个公共类即可,所有逻辑都在 main 方法里,和 C++ 的 main 逻辑完全一致:

java 复制代码
// 类名必须和文件名一致,比如文件叫Main.java,类名就必须是Main(蓝桥杯统一用Main就行)
public class Main {
    // 全局变量(比如数组、常量)必须加static,否则main里不能直接用
    public static final int N = 100010;
    public static int[] arr = new int[N];
    
    // 主方法固定格式,背下来!
    public static void main(String[] args) {
        // 你的解题逻辑(和C++的main里完全一样,只是语法换Java)
        // 比如暴力枚举、递推、BFS/DFS等
    }
    
    // 自定义函数(比如DFS、素数判断)也必须加static,否则main里不能直接调用
    public static boolean isPrime(int x) {
        if (x < 2) return false;
        for (int i = 2; i <= Math.sqrt(x); i++) {
            if (x % i == 0) return false;
        }
        return true;
    }
}

二、输入输出

对于大数据输入题 (比如 1e5 行数据),用Scanner会直接超时,这是 Java 组的高频坑,你需要掌握两种输入方式 (小数据用 Scanner,大数据用 BufferedReader),输出用**System.out**即可。

  • 小数据 Scanner(简单,适合暴力 / 递推题):
java 复制代码
import java.util.Scanner; // 必须导包,和C++的#include一样
public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int a = sc.nextInt(); // 读整数,对应C++的scanf("%d", &a)
        long b = sc.nextLong(); // 读长整数,对应C++的long long
        String s = sc.next(); // 读字符串(无空格)
        sc.close(); // 可选,省赛不用关也没事
    }
}
  • 大数据 BufferedReader:
java 复制代码
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class Main {
    public static void main(String[] args) throws IOException { // 必须抛IOException,否则编译报错
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        int a = Integer.parseInt(br.readLine()); // 读一行转整数
        long b = Long.parseLong(br.readLine()); // 读一行转长整数
        String s = br.readLine(); // 读一行字符串
        // 读多个数:先读行,再分割
        String[] parts = br.readLine().split(" ");
        int c = Integer.parseInt(parts[0]);
        int d = Integer.parseInt(parts[1]);
    }
}

三、Java 基础数据类型 + 大数类

遇到高精度加减乘除、大素数判断、大阶乘等题,直接调 API 就行,不用写任何逻辑,这是 Java 组比 C++ 组轻松的点。

  • 基础类型:记住Java 没有 long long ,8 字节整数用long(声明时加 L,比如10000000000L),避免int溢出(C++ 里的 int 溢出坑 Java 也有,只是类型名不同)。
  • 大数类 BigInteger(省赛核心,只需掌握加减乘除、取模):
java 复制代码
import java.math.BigInteger;
import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        BigInteger a = sc.nextBigInteger();
        BigInteger b = sc.nextBigInteger();
        BigInteger add = a.add(b); // 加,不能用+
        BigInteger sub = a.subtract(b); // 减,不能用-
        BigInteger mul = a.multiply(b); // 乘,不能用*
        BigInteger div = a.divide(b); // 除,不能用/
        BigInteger mod = a.mod(b); // 取模
        System.out.println(add);
    }
}

四、集合框架

java 复制代码
import java.util.ArrayList;
public class Main {
    public static void main(String[] args) {
        ArrayList<Integer> list = new ArrayList<>();
        list.add(1); // 对应vector的push_back
        list.add(2);
        int x = list.get(0); // 对应vector的[0]
        int len = list.size(); // 对应vector的size()
        for (int i = 0; i < len; i++) { // 遍历,和C++一样
            System.out.println(list.get(i));
        }
    }
}
相关推荐
三不原则2 小时前
AIOps 技术架构全景:数据采集→分析→自动化执行全流程
java·架构·自动化
开发者小天2 小时前
python查询天气小示例
开发语言·python
知行合一。。。2 小时前
Python--04--数据容器(元组)
开发语言·python
今天多喝热水2 小时前
SpEL(Spring Expression Language) 表达式
java·后端·spring
wasp5202 小时前
Hudi 客户端实现分析
java·开发语言·人工智能·hudi
学海无涯书山有路2 小时前
Android LiveData + MVVM 新手入门教程(基于 XML+Java)
android·xml·java
Hello.Reader2 小时前
Flink 2.0 从 flink-conf.yaml 到 config.yaml 的正确打开方式(含迁移与最佳实践)
java·前端·flink
李慕婉学姐2 小时前
【开题答辩过程】以《基于uni-app的手账记录小程序的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·小程序·uni-app
啊阿狸不会拉杆2 小时前
《计算机操作系统》 第十一章 -多媒体操作系统
开发语言·c++·人工智能·os·计算机操作系统