面试 | Java 算法的 ACM 模式
前言
经常在 LeetCode 上用核心代码模式刷题的小伙伴突然用 ACM 模式可能会适应不过来,把时间花在输入输出上很浪费时间,因此本篇笔记对 Java 算法的 ACM 模式做了个小总结;
除此之外,需要注意一些小细节:
- 1. 数字读取到字符串读取间需要用 in.nextLine()换行;
1. 数字处理
- 如果是读取 Long,则使用:in.hasNextLong()和Long a = in.nextLong();
- 读取小数:f = scan.nextFloat()或double weight = scan.nextDouble();
1.1 多组空格分隔的两个正整数
输入包括两个正整数a,b(1 <= a, b <= 10^9),输入数据包括多组;
import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while (in.hasNextInt()) { // 注意 while 处理多个 case
            int a = in.nextInt();
            int b = in.nextInt();
            //处理
        }
    }
}
1.2 第一行组数接空格分隔的两个正整数
第一行输入数据个数,后面输入数据;
import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int num = in.nextInt();
        for(int i = 0; i < num; i++) { // 注意 while 处理多个 case
            int a = in.nextInt();
            int b = in.nextInt();
            //处理
        }
    }
}
1.3 空格分隔的两个正整数为0 0 结束
输入包括两个正整数a,b(1 <= a, b <= 10^9), 如果输入为0 0则结束输入;
import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while (in.hasNextInt()) { // 注意 while 处理多个 case
            int a = in.nextInt();
            int b = in.nextInt();
            if(a ==0 && b == 0) break;
            //处理
        }
    }
}
1.4 每行第一个为个数后带空格分割整数为0结束
import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while (in.hasNextInt()) { // 注意 while 处理多个 case
            int n = in.nextInt();
            if(n == 0) break;
            int sum = 0;
            for (int i = 0; i < n; i++) {
                sum += in.nextInt();
            }
            System.out.println(sum);
        }
    }
}
2. 字符串处理
| 比较项 | next( ) | nextLine( ) | 
|---|---|---|
| 说明 | 只能读取到空格之前的字符串 | 可以读取空格的字符串 | 
| 比如“你好 java” | “你好” | “你好 java” | 
| 使用前判断 | in.hasNext() | in.hasNextLine() | 
2.1 第一行个数第二行字符串
import java.util.*;
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int n = in.nextInt();
        in.nextLine();
        while (in.hasNext()) { // 注意 while 处理多个 case
            String[] s = in.nextLine().split(" ");
            //处理
        }
    }
}
2.2 多行空格分开的字符串
import java.util.*;
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while (in.hasNextLine()) { // 注意 while 处理多个 case
            String[] s = in.nextLine().split(" ");
            //处理
        }
    }
}
3. 输出格式化相关
- 输出有两种方式:String str=String.format(示例) 或 System.out.printf(示例);
- 向上取整用:Math.ceil(1.01),向下取整用:Math.floor(1.01);
3.1 转换符
| 转换符 | 说明 | 示例 | 输出 | 
|---|---|---|---|
| %s | 字符串 | "Hi,%s:%s.%s", "王南","王力","王张" | Hi,王南:王力.王张 | 
| %c | 字符 | "字母a的大写是:%c %n", 'A' | 字母a的大写是:A | 
| %b | 布尔 | "3>7的结果是:%b %n", 3>7 | 3>7的结果是:false | 
| %d | 整数(十进制) | "100的一半是:%d %n", 100/2 | 100的一半是:50 | 
| %x | 整数(十六进制) | "100的16进制数是:%x %n", 100 | 100的16进制数是:64 | 
| %o | 整数(八进制) | "100的8进制数是:%o %n", 100 | 100的8进制数是:144 | 
| %f | 浮点 | "50元的书打8.5折扣是:%f 元%n", 50*0.85 | 50元的书打8.5折扣是:42.500000 元 | 
| %a | 浮点(十六进制) | "上面价格的16进制数是:%a %n", 50*0.85 | 上面价格的16进制数是:0x1.54p5 | 
| %e | 指数 | "上面价格的指数表示:%e %n", 50*0.85 | 上面价格的指数表示:4.250000e+01 | 
| %g | 通用浮点(f和e类型中较短的) | "上面价格的指数和浮点数结果的长度较短的是:%g %n", 50*0.85 | 上面价格的指数和浮点数结果的长度较短的是:42.5000 | 
| %h | 散列码 | "字母A的散列码是:%h %n", 'A' | 字母A的散列码是:41 | 
| %% | 百分比 | "上面的折扣是%d%% %n", 85 | 上面的折扣是85% | 
| %n | 换行符 | ||
| %tx | 日期与时间 | 
3.2 搭配转换符的标志
| 标志 | 说明 | 示例 | 输出 | 
|---|---|---|---|
| . | 后接保留多少位小数(四舍五入) | ("%.2f",3.555) | 3.56 | 
| + | 为正数或者负数添加符号 | ("%+d",15) | +15 | 
| − | 左对齐 | ("%-5d",15) | |15 | | 
| 0 | 数字前面补0 | ("%04d", 99) | 0099 | 
| 空格 | 在整数之前添加指定数量的空格 | ("% 4d", 99) | | 99| | 
| , | 以“,”对数字分组 | ("%,f", 9999.99) | 9,999.990000 | 
| ( | 使用括号包含负数 | ("%(f", -99.99) | (99.990000) | 
| # | 如果是浮点数则包含小数点,如果是16进制或8进制则添加0x或0 | ("%#x", 99) ("%#o", 99) | 0x63 0143 | 
| < | 格式化前一个转换符所描述的参数 | ("%f和<3.2f", 99.45) | 99.450000和99.45 | 
| $ | 被格式化的参数索引 | ("%1$d,%2$s", 99,"abc") | 99,abc | 
4. ACM 模式模板
public class Main {
    public static void main(String[] args) {
        //1.数据输入
        Scanner in = new Scanner(System.in);
        //读数字
        int numLen = in.nextInt();
        int[] numArr = new int[numLen];
        int i = 0;
        while(in.hasNextInt() && i < numLen){
            numArr[i] = in.nextInt();
            i++;
        }
        //读字符串
        int strLen = in.nextInt();
        in.nextLine(); //数字到字符串要换行
        String[] strArr = new String[strLen];
        //或者 strArr[] = in.nextLine().split(" ");
        int j = 0;
        while(in.hasNextLine() && j < strLen){
            strArr[j] = in.nextLine();
            j++;
        }
        //2. 处理
        Solution solution = new Solution();
        String result = solution.process(numArr, strArr);
        //3. 输出
        System.out.println(result);
        //四舍五入输出小数
        String str = String.format("%.2f",3.555);
        System.out.println(str);
    }
}
//下面类似 LeetCode 的核心代码模式
class Solution {
    public String process(int[] nums, String[] strs) {
        StringBuilder sb = new StringBuilder();
        sb.append(Arrays.toString(nums));
        sb.append(" && ");
        sb.append(Arrays.toString(strs));
        return sb.toString();
    }
}
最后
新人制作,如有错误,欢迎指出,感激不尽! 欢迎关注公众号,会分享一些更日常的东西! 如需转载,请标注出处! 
面试 | Java 算法的 ACM 模式的更多相关文章
- 面试-java算法题
		1.编写一个程序,输入n,求n!(用递归的方式实现). public static long fac(int n){ if(n<=0) return 0; else if(n==1) retur ... 
- 面试:用 Java 实现一个 Singleton 模式
		面试:用 Java 实现一个 Singleton 模式 面试系列更新后,终于迎来了我们的第一期,我们也将贴近<剑指 Offer>的题目给大家带来 Java 的讲解,个人还是非常推荐< ... 
- java面试题----工厂模式大整理(面试问的较多)
		在一次面试中了解到工厂模式在实际应用中的重要性,可以说工厂模式的应用随处可见,以下是百度百科对工厂模式的介绍 工厂模式是我们最常用的实例化对象模式了,是用工厂方法代替new操作的一种模式.著名的Jiv ... 
- 编程之法:面试和算法心得(字符串包含java实现)
		内容全部来自编程之法:面试和算法心得一书,实现是自己写的使用的是java 题目描述 给定两个分别由字母组成的字符串A和字符串B,字符串B的长度比字符串A短.请问,如何最快地判断字符串B中所有字母是否都 ... 
- 编程之法:面试和算法心得(旋转字符串java实现)
		内容全部来自编程之法:面试和算法心得一书,实现是自己写的使用的是java 题目描述 给定一个字符串,要求把字符串前面的若干个字符移动到字符串的尾部,如把字符串“abcdef”前面的2个字符'a'和'b ... 
- 分享系列--面试JAVA架构师--链家网
		本月7日去了一趟链家网面试,虽然没有面上,但仍有不少收获,在此做个简单的分享,当然了主要是分享给自己,让大家见笑了.因为这次是第一次面试JAVA网站架构师相关的职位,还是有些心虚的,毕竟之前大部分时间 ... 
- 2015年阿里实习生面试Java研发工程师 小记
		5月5日,广州,阿里实习生面试,Java研发工程师,完全被虐orz 几乎没有Java项目开发经验,接近零基础,去水了一发,毫无悬念的被刷了..RP也是杠杠的,准备过的题目一个都没被问到,算法题也是一条 ... 
- Java中的策略模式,完成一个简单地购物车,两种付款策略实例教程
		策略模式是一种行为模式.用于某一个具体的项目有多个可供选择的算法策略,客户端在其运行时根据不同需求决定使用某一具体算法策略. 策略模式也被称作政策模式.实现过程为,首先定义不同的算法策略,然后客户端把 ... 
- java运行时内存模式学习
		学习java运行时内存模式: 各区介绍: 方法区(线程共享):用于存放被虚拟机加载的类的元数据:静态变量,常量,以及编译和的代码(字节码),也称为永久代(所有该类的实例被回收,或者此类classLoa ... 
随机推荐
- LGP5142题解
			题意简明,不说了( 因为教练让同学们做线段树的题,早就会了线段树的我就来爆踩水水蓝了/kk 首先推一下柿子: \[\frac 1 n\sum_{i=1}^n(a_i^2-2 \times a_i \t ... 
- [ Shell ] 两个 case 实现 GetOptions 效果
			https://www.cnblogs.com/yeungchie/ 可以用 getopt,但我还是喜欢自己写这个过程,便于我够控制更多细节. 下面要实现的效果是,从命令行参数中分析,给 $libNa ... 
- vmware下的manjaro挂载共享文件夹
			开始时在archwiki上看到的是以下命令 mkdir <shared folders root directory> vmware-hgfsclient vmhgfs-fuse -o a ... 
- 学习Spring资料
			参考文档 官方文档 源码分析 书籍 Spring5核心原理与30个类手写实战 Spring技术内幕 视频 bilibili 
- [NPUCTF2020]Baby Obfuscation wp
			整体观察main函数,可以发现用户自定义函数和变量存在混淆,猜测为函数名及变量名asc混淆. 对函数进行分析: Fox1为欧几里得算法求最大公约数 Fox5其实是pow Fox4根据逻辑数学的法则实际 ... 
- error LNK2019: 无法解析的外部符号 _WinMain@16,该符号在函数。。。使用
			一,问题描述 MSVCRTD.lib(crtexew.obj) : error LNK2019: 无法解析的外部符号 _WinMain@16,该符号在函数 ___tmainCRTStartup 中被引 ... 
- SpringBoot中的日志使用:
			SpringBoot中的日志使用(一) 一:日志简介: 常用的日志接口 commons-logging/slf4j 日志框架:log4j/logback/log4j2 日志接口屏蔽了日志框架的底层实现 ... 
- char型变量中能不能存储一个中文字符?为什么?
			char型变量是用来存储Unicode编码的字符的,Unicode编码字符集中包含了汉字,因此char型变量中可以存储汉字.不过,如果某个特殊的汉字没有被包含在Unicode编码字符集中,那么,这个c ... 
- 什么是springboot?为什么要用springboot?
			一.什么是springboot? Springboot是spring发展到一定程度的产物,但并不是spring的替代品,springboot是为了让程序员更好的使用spring.Spring随着发展逐 ... 
- kafka 分布式(不是单机)的情况下,如何保证消息的顺序消费?
			Kafka 分布式的单位是 partition,同一个 partition 用一个 write ahead log 组织, 所以可以保证 FIFO 的顺序.不同 partition 之间不能保证顺序. ... 
