JAVA算法竞赛输入输出专题[通俗易懂]

JAVA算法竞赛输入输出专题[通俗易懂]小编由于报名了蓝桥杯Java组,所以日常做题从使用C/C++转变成使用Java。在转变的过程中,肯定会遇到很多大大小小的输入输出问题。小编打算总结下来,当做自己学习的材料,也分享给感兴趣的朋友。

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

2020.2.23更新,增加了数组模块


前言

小编由于报名了蓝桥杯Java组,所以日常做题从使用C/C++转变成使用Java。在转变的过程中,肯定会遇到很多大大小小的输入输出问题。小编打算总结下来,当做自己学习的材料,也分享给感兴趣的朋友。

文件名问题

在比赛提交的代码中,主类必须以public class Main来命名,而且不能带package语句否则会报出编译错误。

//去掉public或者不使用Main作为类名都会gg,亲测有效orz

基本的输入和输出

竞赛入门最经典的问题,莫过于A+B Problem,如果连最基本的输入输出都做不到,学了再多的算法也用不出来。

import java.util.*;
public class Main { 
   

	public static void main(String[] args) { 
   
		Scanner cin = new Scanner(System.in);
		int a, b;
		while (cin.hasNext()) { 
   
			a = cin.nextInt();
			b = cin.nextInt();
			System.out.println(a + b);
		}
	}
}

上面代码展示了最基本的输入输出框架,输入类Scanner包含在java.util类包中,首先应该把它导入。

import java.util.*;

由于java的输入需要预先创建输入类对象,所以我们一般习惯在main函数的第一句先创建这个Scanner类对象,对象命名为cin算是表达对C/C++的热爱和怀念吧hhh
如果题目数据量比较大的话可以选择第二种初始化方法,运行效率会高上一些。

Scanner cin = new Scanner(System.in);
//or
Scanner cin = new Scanner(new BufferedInputStream(System.in));

由于题目说明“输入包括多组数据,到文件结尾为止”,类比C/C++的格式,我们很容易理解以下的这段java代码

while (cin.hasNext())  //当输入流中还有数据时
{ 
   
    a = cin.nextInt();
	b = cin.nextInt();
}

1.基本数据类型

这些类型在C/C++中基本上已经用烂了,一般过目一遍就会了。

int n = cin.nextInt();//读入一个整数
double d = cin.nextDouble();//读入一个双精度浮点数
long l = cin.nextLong();//读入一个长整型数

需要注意一点:由于Java的main方法是static类型,所以定义全局变量或者方法的时候就需要加上static关键字!

2.数组

关于数组的创建,Java和C/C++也有所不同,它在创建时需要使用new关键字来为其分配存储空间,不过也不会非常麻烦。

int arr[] = new int[Size];
//or
int []arr = new int[Size];

对于二维数组的初始化问题,可以看看我写的另一篇文章:Java 二维数组的初始化

3.字符&字符串

Scanner类中并没有提供单个字符char类型的读入方法,但是我们可以先调用next()方法读取只包含一个字符的字符串,然后用charAt(0)返回0号索引处的字符,即可得到读取到单个字符。

char ch = cin.next().charAt(0);

对于字符串,java中已经封装好了字符串String类,我们也可以用char数组在进行字符串存储。

String str1 = next(); //相当于C/C++中的scanf("%s",str);或cin>>str;
String str2 = nextLine();//相当于C/C++中的gets(str2);或者getline(cin,str2);

char s1[] = cin.next().toCharArray();//调用toCharArray()方法将其转化为char类型数组
char s2[] = cin.nextLine().toCharArray();//类比理解

但是要注意的是,我们不能像C++那样直接用数组下标去访问String类对象中的某号字符。 我们通常利用charAt(int index)方法来访问String类对象中的某号字符,或者不需要调用String类的其他方法的情况下,直接采用char类型数组来存储字符串。

4.输出

日常基本的输出:

System.out.println(); //相当于C++中的cout<<endl;
System.out.print();   //相当于C++中的cout<<"";

输出到文件中:
以下情况可能会用到输出到文件中

  • 当数据量过于庞大,java的控制台都无法输出,需要输出到文件中。
  • 用暴力法打表,需要按格式先输入到文件中。
try { 
   
	BufferedWriter bw = new BufferedWriter(new FileWriter(new File("E://result.txt")));
	bw.write(str);//str表示写入文件的内容
	bw.flush();//立刻将缓存区的数据写入数据流
	bw.close();//将BufferedWriter流关闭
} catch (Exception e) { 
   
	e.printStackTrace();
}

File(string pathname); 用于初始化文件类,pathname表示文件的路径
FileWriter(File file); 用于初始化文件写入类FileWriter,file表示文件类对象

未完待续…

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Oracle数据库中 dbms_output.put_line 不显示的问题解决方案

    @Json.Xu 在学习Oracle的过程中学到匿名语句块在执行过程中发现控制台打印输出DBMS_OUTPUT.PUT_LINE(vename||’过节费’||vmsg);的时候并不显示。一下是我的数据库代码declare vename varchar2(20); vsal_comm emp.sal%type; vcomm emp.comm%type; …

    2021年11月30日
    61
  • Mysql 8.0解压版下载安装及配置教程

    Mysql 8.0解压版下载安装及配置教程首先声明,这里是Mysql8.0.27版本、64位操作系统解压版mysql的下载及安装配置及修改初始密码。如果是其他版本的mysql安装,可以自行查找其他方法,记住搜索的时候最好加上是什么版本的,因为不同版本的mysql安装的时候有些命令是不同的,例如,mysql5.7的就搜索mysql5.7安装。话不多说,接下来就是我的mysql8.0.27版本的教程了。1.下载打开下载地址:https://dev.mysql.com/downloads/mysql/,找到箭头中的文件https:/

    2022年5月8日
    49
  • java中Switch(expr)里面的参数的类型是?

    java中Switch(expr)里面的参数的类型是?在Java5以前,switch(expr)中,exper只能是byte,short,char,int类型在JDK1.6:引入enumJDK1.7时:又增加了Stringpublic static void main(String[] args) { switch ("123") { case "123": System.out.println("1234"); b…

    2022年6月13日
    39
  • Jmeter安装步骤「建议收藏」

    Jmeter安装步骤「建议收藏」1、官网下载地址:http://jmeter.apache.org/download_jmeter.cgi2、下载到本地(我是D盘中:存放目录最好都是英文)3、配置环境变量:(window10:设置-》系统-》关于-》系统信息-》高级系统设置-》-OK)4、此处为我的安装目录:变量名称 变量值 JMETER_HOME D:\testsoft\apac…

    2022年6月5日
    26
  • nfs方式启动rootfs配置过程[通俗易懂]

    nfs方式启动rootfs配置过程[通俗易懂]这里使用nfs主要是做rootfs挂载。开发板中运行kernel做nfs客户端,宿主机中运行nfs服务。在宿主机的nfs服务器中导出文件夹形式的rootfs目录,在客户端中去挂载这个文件夹形式的rootfs进而去启动系统。

    2022年9月27日
    2
  • Linux内核版本查看_mysql隐藏版本号

    Linux内核版本查看_mysql隐藏版本号1、使用uname命令查找Linux内核2、使用/proc/version文件查找Linux内核3、使用dmesg命令查找Linux内核版本4、使用hostnamectl命令查看Linux内核版本

    2022年10月13日
    0

发表回复

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

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