热门标签 | 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;}}
}


推荐阅读
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 实用正则表达式有哪些
    小编给大家分享一下实用正则表达式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下 ... [详细]
  • golang常用库:配置文件解析库/管理工具viper使用
    golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 本文介绍了如何使用 Spring Boot DevTools 实现应用程序在开发过程中自动重启。这一特性显著提高了开发效率,特别是在集成开发环境(IDE)中工作时,能够提供快速的反馈循环。默认情况下,DevTools 会监控类路径上的文件变化,并根据需要触发应用重启。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • CMake跨平台开发实践
    本文介绍如何使用CMake支持不同平台的代码编译。通过一个简单的示例,我们将展示如何编写CMakeLists.txt以适应Linux和Windows平台,并实现跨平台的函数调用。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • 优化联通光猫DNS服务器设置
    本文详细介绍了如何为联通光猫配置DNS服务器地址,以提高网络解析效率和访问体验。通过智能线路解析功能,域名解析可以根据访问者的IP来源和类型进行差异化处理,从而实现更优的网络性能。 ... [详细]
  • 本文详细分析了JSP(JavaServer Pages)技术的主要优点和缺点,帮助开发者更好地理解其适用场景及潜在挑战。JSP作为一种服务器端技术,广泛应用于Web开发中。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 本文深入探讨了HTTP请求和响应对象的使用,详细介绍了如何通过响应对象向客户端发送数据、处理中文乱码问题以及常见的HTTP状态码。此外,还涵盖了文件下载、请求重定向、请求转发等高级功能。 ... [详细]
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社区 版权所有