当前位置: 首页 > news >正文

java-算法基础优化

一、ACM风格输入输出(高效,替换原有的输入输出流)

1.推荐原因:(内存托管)

对于原本的Scanner读取流,只能根据行来读取数据,而BufferredReader读取信息可以直接读取整个文件,动态地调用读取方法(给你一个指针,指向了以空格和换行分割的输入内容的缓存,通过调用方法直接从缓存中读取数据),从而提高IO效率。

同理,对于原本的System.out输出,我们也可以使用这种缓存托管的思想来控制输出,避免读取一次数据就只发一次信息,需要多次IO

2.BufferedReader读取

引入BufferedReader

static BufferedReader br = new BufferedReader(new InputStreamReader(new BufferedInputStream(System.in)));
(1)一般使用:

和Scanner差不多,是按行读取数据

调用br--BufferedReader 的对象

String input = br.readLine();
int input = br.read();
(2)进阶使用:

通过控制指针,按需读取信息(已经根据空格和换行切分好了,按单一获取数据)

创建托管对象:StreamTokenizer

static BufferedReader br = new BufferedReader(new InputStreamReader(System.in));

StreamTokenizer st = new StreamTokenizer(br);

获取st指针中的信息:

int aaa = st.nval

更新指针指向:

st.nextToken();

3.PrintWriter输出

引入PrintWriter:

static PrintWriter out =new PrintWriter(new OutputStreamWriter(System.out));

执行输出:

注意,输出需要调用两个方法,

  • .println方法看起来是输出,实际上是将信息存入输出缓存
out.println(st.nval);// out是前面定义的对象,这是调用对象的方法
  • .flush方法其实是一口气把所有缓存数据输出
out.flush()// out是前面定义的对象,这是调用对象的方法

4.实际使用:

主要是存在大量数据时才使用

  1. 完成输入输出流的引入
/**
    和前面一样
*/
  1. 编写循环,控制读取并输出
while(in.nextToken()!=StreamTokenizer.TT_EOF){
    
    // 一系列操作

    out.println(st.nval);// out是前面定义的对象,这是调用对象的方法
}
out.flush()// out是前面定义的对象,这是调用对象的方法
  1. 关闭流资源
out.close;
br.close
// st不是流资源

二、静态化储存空间(手动复用的内存,减少判定时内存的损耗)

1.推荐原因:(复用内存)

在算法比赛中,每次开辟空间都算做一次内存增加,如果碰到大数据、多循环的情况,可能判定内存过大,为了减少这种情况,我们不妨对复用型的存储空间进行静态化、固定化

2.实现方法:

静态化存储空间,后续手动控制其增删改查

public static int MAX_N = 800;
public static int MAX_M = 800;

public static int[][] arr = new int[MAX_N][MAX_M]

相关文章:

  • FreeSWITCH 之 chat
  • 脏读、不可重复读,幻读的区别 mvcc及四种隔离级别
  • 2025年3家大牌云电脑游戏、AIGC大PK,最低0.1元,配置不再是问题
  • ⭐LeetCode(数学分类) 48. 旋转图像——优美的数学法转圈(原地修改)⭐
  • 《领导力21法则》第三章「过程法则」笔记
  • Sentinel-1 InSAR ISCE数据处理:stackSentinel.py 完全指南
  • 考研数学复习之拉格朗日中值定理求解函数极限
  • 深入链表操作:C语言中的链表中间节点查找与合并
  • 《Android 平台架构系统启动流程详解》
  • sparkTTS window 安装
  • MFC 项目:简易销售系统实践
  • MoonSharp 文档四
  • LLM学习之路-01-第一章-预训练/搞懂大模型的分词器(二)
  • electron builder打包时,出现errorOut=ERROR: Cannot create symbolic link
  • Talking Head Review (数字人算法综述)
  • Django 初始化导入数据详解
  • 数据结构:有序表的合并
  • Unity 扩散式布局
  • Unity 带阻尼感的转盘
  • 数智读书笔记系列015 探索思维黑箱:《心智社会:从细胞到人工智能,人类思维的优雅解读》读书笔记
  • 欧盟拟对发往欧洲的小额包裹加收手续费,外交部回应
  • 马上评|当众猥亵女演员,没有任何开脱理由
  • 萨洛宁、康托罗夫、长野健……7月夏季音乐节来很多大牌
  • 香港新股市场繁荣:恒瑞医药等4公司同时招股,宁德时代今日港交所上市
  • 上海发文加强直播经济技能人才培养:三年新培养持证直播技能人才5万名
  • 曾毓群说未来三年重卡新能源渗透率将突破50%,宁德时代如何打好换电这张牌