热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

蓝桥竞赛:回形取数问题的正确实现代码解析

蓝桥竞赛中的回形取数问题是一个经典的算法挑战。本文详细解析了该问题的正确实现代码,重点探讨了`hasNext()`和`next()`方法的区别与应用。尽管两者在功能上类似,都会等待用户输入下一个字符,但它们的返回值类型不同,`hasNext()`返回一个布尔值,表示是否还有输入,而`next()`则直接返回下一个输入的值。通过具体的代码示例和详细的逻辑分析,本文为参赛者提供了宝贵的参考和指导。
蓝桥:回形取数

hasNext()和Next()效果其实是一样的,系统都会等待输入下一个字符,只是返回值不同,hasNext()会返回true,next()返回输入的字符。

A=[表达式]?a:b;
等价于
if(表达式)A=a;
else A=b;

回车、换行的区别
他们间的区别其实是个回车换行的问题

先来段历史

回车”(Carriage Return)和“换行”(Line Feed)这两个概念的来历和区别。

符号 ASCII码 意义

\n 10 换行

\r 13 回车CR

在计算机还没有出现之前,有一种叫做电传打字机(Teletype Model 33,Linux/Unix下的tty概念也来自于此)的玩意,每秒钟可以打10个字符。但是它有一个问题,就是打完一行换行的时候,要用去0.2秒,正好可以打两个字符。要是在这0.2秒里面,又有新的字符传过来,那么这个字符将丢失。

于是,研制人员想了个办法解决这个问题,就是在每行后面加两个表示结束的字符。一个叫做“回车”,告诉打字机把打印头定位在左边界;另一个叫做“换行”,告诉打字机把纸向下移一行。这就是“换行”和“回车”的来历,从它们的英语名字上也可以看出一二。

后来,计算机发明了,这两个概念也就被般到了计算机上。那时,存储器很贵,一些科学家认为在每行结尾加两个字符太浪费了,加一个就可以。于是,就出现了分歧。

在Windows中:

‘\r’ 回车,回到当前行的行首,而不会换到下一行,如果接着输出的话,本行以前的内容会被逐一覆盖;

‘\n’ 换行,换到当前位置的下一行,而不会回到行首;

Unix系统里&#xff0c;每行结尾只有“<换行>”&#xff0c;即"\n"&#xff1b;Windows系统里面&#xff0c;每行结尾是“<回车><换行>”&#xff0c;即“\r\n”&#xff1b;Mac系统里&#xff0c;每行结尾是“<回车>”&#xff0c;即"\r"&#xff1b;。一个直接后果是&#xff0c;Unix/Mac系统下的文件在Windows里打开的话&#xff0c;所有文字会变成一行&#xff1b;而Windows里的文件在Unix/Mac下打开的话&#xff0c;在每行的结尾可能会多出一个^M符号。

例:

$ echo -en ‘12\n34\r56\n\r78\r\n’ > tmp.txt

分别在Windws和Linux中查看此文件可知:
Linux中遇到换行符("\n")会进行回车&#43;换行的操作&#xff0c;回车符反而只会作为控制字符("^M")显示&#xff0c;不发生回车的操作。而windows中要回车符&#43;换行符("\r\n")才会回车&#43;换行&#xff0c;缺少一个控制符或者顺序不对都不能正确的另起一行。

本质的分析&#xff0c;请参考 C&#43;&#43;中回车换行&#xff08;\n\r&#xff09;和换行(\r)的区别

注意点&#xff1a;

在解析文本或其他格式的文件内容时&#xff0c;常常要碰到判定回车换行的地方&#xff0c;这个时候就要注意既要判定"\r\n"又要判定"\n"。

写程序时可能得到一行,将其进行trim掉’\r’,这样能得到你所需要的string了。

import java.util.Scanner;public class 回形针取数 {public static void main(String[] args) {Scanner sc&#61;new Scanner(System.in);int m&#61;sc.nextInt();int n&#61;sc.nextInt();int[][] flag&#61;new int[m][n];//标记路径int[][] arr &#61;new int[m][n];//定义数据for(int i&#61;0;i<m;i&#43;&#43;){for(int j&#61;0;j<n;j&#43;&#43;){arr[i][j]&#61;sc.nextInt();}}int count&#61;m*n;//count为写入的总大小int i&#61;0;int j&#61;0;while(count>0){while(i<m&&flag[i][j]&#61;&#61;0){System.out.print(arr[i][j]);System.out.print(--count &#61;&#61; 0 ? "\r\n":" ");//加了减减&#xff0c;每输出一个count进行减1.之前count&#61;6&#xff0c;此时变为5&#xff0c;flag[i][j]&#61;1;i&#43;&#43;;}//输入132456&#xff0c;输出1 3 5 此时i边为3&#xff0c;变为了2i--;//所以i要减一个j&#43;&#43;;//要到6&#xff0c;arr[2][1]&#61;6while(j<n&&flag[i][j]&#61;&#61;0){System.out.print(arr[i][j]&#43;" ");System.out.print(--count &#61;&#61; 0 ? "\r\n":" ");flag[i][j]&#61;1;j&#43;&#43;;//6&#xff0c;count&#61;1}j--;//j&#61;1i--;//i&#61;1 到了arr[1][1]&#61;4while(i>-1&&flag[i][j]&#61;&#61;0){System.out.print(arr[i][j]&#43;" ");//输出4System.out.print(--count&#61;&#61;0?"\r\n":" ");//输出空格,count&#61;0了&#xff0c;直接回车换行了&#xff0c;即是退出循环&#xff0c;结束程序flag[i][j]&#61;1;//flag[1][1]&#61;1;i--;//i&#61;0 输出2 flag[0][1]&#61;1;i&#61;-1;}i&#43;&#43;;//i&#61;&#61;0j--;//j&#61;0;while(j>-1&&flag[i][j]&#61;&#61;0){//可是这时候已经全部完成了&#xff0c;所以此时flag[0][0]&#61;&#61;1;不符合System.out.print(arr[i][j]&#43;" ");System.out.print(--count&#61;&#61;0?"\r\n":" ");flag[i][j]&#61;1;j--;}j&#43;&#43;;//j&#61;1i&#43;&#43;;//i&#61;1 这样不就是变成了死循环吗&#xff1f;}}
}


推荐阅读
  • 开发笔记:9.八大排序
    开发笔记:9.八大排序 ... [详细]
  • 异常要理解Java异常处理是如何工作的,需要掌握一下三种异常类型:检查性异常:最具代表性的检查性异常是用户错误或问题引起的异常ÿ ... [详细]
  • 深入解析Java枚举及其高级特性
    本文详细介绍了Java枚举的概念、语法、使用规则和应用场景,并探讨了其在实际编程中的高级应用。所有相关内容已收录于GitHub仓库[JavaLearningmanual](https://github.com/Ziphtracks/JavaLearningmanual),欢迎Star并持续关注。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • JavaScript 基础语法指南
    本文详细介绍了 JavaScript 的基础语法,包括变量、数据类型、运算符、语句和函数等内容,旨在为初学者提供全面的入门指导。 ... [详细]
  • 本文将探讨Java编程语言中对象和类的核心概念,帮助读者更好地理解和应用面向对象编程的思想。通过实际例子和代码演示,我们将揭示如何在Java中定义、创建和使用对象。 ... [详细]
  • 本题探讨了在一个有向图中,如何根据特定规则将城市划分为若干个区域,使得每个区域内的城市之间能够相互到达,并且划分的区域数量最少。题目提供了时间限制和内存限制,要求在给定的城市和道路信息下,计算出最少需要划分的区域数量。 ... [详细]
  • 本文探讨了在C++中如何有效地清空输入缓冲区,确保程序只处理最近的输入并丢弃多余的输入。我们将介绍一种不阻塞的方法,并提供一个具体的实现方案。 ... [详细]
  • 本问题探讨了在特定条件下排列儿童队伍的方法数量。题目要求计算满足条件的队伍排列总数,并使用递推算法和大数处理技术来解决这一问题。 ... [详细]
  • 深入理解Lucene搜索机制
    本文旨在帮助读者全面掌握Lucene搜索的编写步骤、核心API及其应用。通过详细解析Lucene的基本查询和查询解析器的使用方法,结合架构图和代码示例,带领读者深入了解Lucene搜索的工作流程。 ... [详细]
  • 深入解析for与foreach遍历集合时的性能差异
    本文将详细探讨for循环和foreach(迭代器)在遍历集合时的性能差异,并通过实际代码示例和源码分析,帮助读者理解这两种遍历方式的不同之处。文章内容丰富且专业,旨在为编程爱好者提供有价值的参考。 ... [详细]
  • 使用Python计算文件的CRC32校验值
    本文记录了一次对路由器固件分析时,如何利用Python计算文件的CRC32校验值。文中提供了完整的代码示例,并详细解释了实现过程。 ... [详细]
  • 本文介绍了如何利用Python进行批量图片尺寸调整,包括放大和等比例缩放。文中提供了详细的代码示例,并解释了每个步骤的具体实现方法。 ... [详细]
  • 使用lambda表达式排序Collections.sort(temp,(Stringa,Stringb)-{returnb.compareTo(a);});Collections ... [详细]
  • 丽江客栈选择问题
    本文介绍了一道经典的算法题,题目涉及在丽江河边的n家特色客栈中选择住宿方案。两位游客希望住在色调相同的两家客栈,并在晚上选择一家最低消费不超过p元的咖啡店小聚。我们将详细探讨如何计算满足条件的住宿方案总数。 ... [详细]
author-avatar
一个不需要幸福的男人丶
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有