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


推荐阅读
  • 实用正则表达式有哪些
    小编给大家分享一下实用正则表达式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 深入理解Shell脚本编程
    本文详细介绍了Shell脚本编程的基础概念、语法结构及其在操作系统中的应用。通过具体的示例代码,帮助读者掌握如何编写和执行Shell脚本。 ... [详细]
  • 本文介绍如何从字符串中移除大写、小写、特殊、数字和非数字字符,并提供了多种编程语言的实现示例。 ... [详细]
  • Linux环境下进程间通信:深入解析信号机制
    本文详细探讨了Linux系统中信号的生命周期,从信号生成到处理函数执行完毕的全过程,并介绍了信号编程中的注意事项和常见应用实例。通过分析信号在进程中的注册、注销及处理过程,帮助读者理解如何高效利用信号进行进程间通信。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • CMake跨平台开发实践
    本文介绍如何使用CMake支持不同平台的代码编译。通过一个简单的示例,我们将展示如何编写CMakeLists.txt以适应Linux和Windows平台,并实现跨平台的函数调用。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 本文详细介绍了网络存储技术的基本概念、分类及应用场景。通过分析直连式存储(DAS)、网络附加存储(NAS)和存储区域网络(SAN)的特点,帮助读者理解不同存储方式的优势与局限性。 ... [详细]
  • 本文深入探讨了UNIX/Linux系统中的进程间通信(IPC)机制,包括消息传递、同步和共享内存等。详细介绍了管道(Pipe)、有名管道(FIFO)、Posix和System V消息队列、互斥锁与条件变量、读写锁、信号量以及共享内存的使用方法和应用场景。 ... [详细]
  • 本文详细解析了Java中throw和throws的关键区别,同时涵盖了JDK的定义、Java虚拟机的关键约定、Java的跨平台性、自动垃圾回收机制、源文件结构、包的概念及作用等多个核心知识点,旨在帮助学生更好地准备Java期末考试。 ... [详细]
  • 深入探讨CPU虚拟化与KVM内存管理
    本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ... [详细]
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社区 版权所有