Java中Scanner的用法:单行/多行输入

Java中Scanner的用法:单行/多行输入Java的Scanner用法,主要用于算法笔试时的控制台输入问题:解决这种情况下的Scanner输入:单行,多行,数值,字符串最好解决的情况单行输入多个字符串多行输入多个字符串问题:解决这种情况下的Scanner输入:单行,多行,数值,字符串平时写程序一般不用Scanner,线上笔试的时候,各大公司热衷于Scanner输入。平时用LeetCode刷题也不会用到,结果多次在笔试时候卡在Scan……

大家好,又见面了,我是你们的朋友全栈君。

1 问题:解决这种情况下的Scanner输入:单行,多行,数值,字符串

平时写程序一般不用Scanner,线上笔试的时候,各大公司热衷于Scanner输入。
平时用LeetCode刷题也不会用到,结果多次在笔试时候卡在Scanner,特来总结一波。

2 最好解决的情况

多行输入元素,其中第一行几个数字表示下面几行的个数。

以三行输入为例,第一行输入两个数字m,n,分别表示数组num1和num2的长度,第二行和第三行输入num1和num2的元素,以空格分隔。

// 输入如下
3 4
10 2 3 
11 4 5 6

程序如下:

import java.util.Arrays;
import java.util.Scanner;

public class myScanner { 
   
	Scanner sc = new Scanner(System.in);
	public static void main(String[] args) { 
   
		System.out.println("输入:");
		Scanner sc = new Scanner(System.in);
		int m = sc.nextInt();
		int n = sc.nextInt();
		int[] num1 = new int[m];
		int[] num2 = new int[n];
		// 换成其他数据类型也一样,其他数值类型就修改int跟nextInt就可以了,
		//String就把nextInt()换成next()
		for(int i = 0; i < m; i ++) { 
   
			num1[i] = sc.nextInt();  // 一个一个读取
		}
		for(int i = 0; i < n; i ++) { 
   
			num2[i] = sc.nextInt();
		}
		System.out.println("输出:");
		System.out.println(Arrays.toString(num1));
		System.out.println(Arrays.toString(num2));
	}
}

运行示例:
在这里插入图片描述在这里插入图片描述
换成其他数据类型也一样,其他数值类型就修改int跟nextInt就可以了,String就把nextInt()换成next()

3 单行输入多个参数

在一行输入多个参数

以空格(也可用其他的符号,不重要)为分割。

// 输入如下
ABB CCC DDD  EEE 123 435

程序如下:

import java.util.Arrays;
import java.util.Scanner;

public class myScanner { 
   
	Scanner sc = new Scanner(System.in);
	public static void main(String[] args) { 
   
		System.out.println("输入:");
		Scanner sc = new Scanner(System.in);
		String str = sc.nextLine();  // 读取一行
		System.out.println("输出:");
		System.out.println(str);
		String[] strIn = str.trim().split(" ");  // 以空格分割
		System.out.println(Arrays.toString(strIn));
	}
}

读出来的只能是字符串,如果想全部为数字,需要将读出来的字符串强行转换为数字(parseInt、parseLong等),运行示例如下:
在这里插入图片描述

4 多行输入多个参数,每行参数个数不定

每行输入不等数量的参数

这种情况下,或者可以从题干直接确定行数,或者能够从输入的第一行输入的某个参数确定下面还有几行。
以后者为例进行说明,假设第一行输入m,n,m表示后面有m行,n表示每行最多有n个(可用来截断某一行多输入的参数,不详细分析了)。

// 输入如下
3 4
AA bcd 123 54
AA BB
A B C

程序如下:

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Scanner;

public class myScanner { 
   
	Scanner sc = new Scanner(System.in);
	public static void main(String[] args) { 
   
		System.out.println("输入:");
		Scanner sc = new Scanner(System.in);
		int m = sc.nextInt();
		sc.nextLine();  // 很重要,跳到第二行
		// 若直接确定行数,注释掉上面两行,加入下面一行
		// int m = 3;
		String[] strArr = new String[m];
		// 从第二行开始读取
		for(int i = 0; i < m; i++) { 
   
			strArr[i] = sc.nextLine();
		}
		System.out.println("输出:");
		System.out.println(Arrays.toString(strArr));
		ArrayList<String[]> strToOne = new ArrayList<String[]>();
		for(int i = 0; i < m; i ++) { 
   
			String[] tmp = strArr[i].trim().split(" ");
			strToOne.add(tmp);
		}
		System.out.println(strToOne);
		// 形象点显示
		System.out.print("[");
		for(int i = 0; i < strToOne.size(); i++) { 
   
			System.out.print(Arrays.toString(strToOne.get(i)));
			if(i != strToOne.size()-1)
				System.out.print(", ");
		}
		System.out.print("]");
	}
}

运行结果如下:
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/162028.html原文链接:https://javaforall.net

(1)
上一篇 2022年7月20日 下午6:16
下一篇 2022年7月20日 下午6:16


相关推荐

  • git 同时使用gitlab和github

    git 同时使用gitlab和github开发者经常是公司的 gitlab 和 github 同时使用 但是 ssh 的配置只能配置一个 这种情况该如何处理参考 同一台电脑同时使用 gitHub 和 gitLab 给你一页白纸 博客园但需要将生成 github 的秘钥添加到 ssh agent 中 参考 生成新 SSH 密钥并添加到 ssh agent GitHubDocsss add ssh id ed25519 权限报错参考 Error Permissionde publickey GitH

    2026年3月19日
    2
  • Mysql中的 not null

    Mysql中的 not null创建医生信息表 doctor info1 doctor info2 区别是 doctor info1 中 doctor name 加上 notnull 约束 CREATETABLE doctor info1 id bigint 20 NOTNULLAUTO INCREMENT doctor name varchar 32 NOTNULL doct

    2026年3月17日
    2
  • android viewpager实现轮播「建议收藏」

    android viewpager实现轮播「建议收藏」本文是基于ViewPager实现的无限自动轮播banner分为三步:第一部分是有限手动轮播;第二部分是无限轮播;第三部分是自动轮播;第四部分是指示器适配有限手动轮播实现:布局:<androidx.viewpager.widget.ViewPagerandroid:id=”@+id/banner”android:layout_width=”match_parent”android:layout_height=”wrap_content”andro

    2022年7月22日
    14
  • 秒杀系统设计的 5 个要点:前端三板斧+后端两条路!(建议收藏)

    点击上方“全栈程序员社区”,星标公众号 重磅干货,第一时间送达 秒杀系统涉及到的知识点: 高并发,cache,锁机制 基于缓存架构redis,Memcached的先进先出队列。 稍…

    2021年6月23日
    112
  • c++算法之最长递增子序列(LIS)

    c++算法之最长递增子序列(LIS)题目:输入一个整数n,随后输入n个整数,求这个长度为n的序列中严格递增的子序列的最长长度。例:输入:6143265输出:3解题思路:动态规划。将输入的序列存入一个数组v中,另外再定义一个数组a,用以存储以当前数字v[i]结尾时,最长递增子序列的长度是多少。定义数组时,全部初始化为1,初始状态表示的是最坏的情况,以v[i]结尾的最长递增子序列就是v[i]它本身,长度为1。接着将v[i]逐一…

    2022年6月3日
    32
  • Idea激活码永久有效Idea2021.1激活码教程-持续更新,一步到位[通俗易懂]

    Idea激活码永久有效Idea2021.1激活码教程-持续更新,一步到位[通俗易懂]Idea激活码永久有效2021.1激活码教程-Windows版永久激活-持续更新,Idea激活码2021.1成功激活

    2022年6月17日
    44

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号