每日一题(小白)模拟娱乐篇33

首先,理解题意是十分重要的,我们是要求最短路径,这道题可以用dfs,但是题目给出的数据是有规律的,我们可以尝试模拟的过程使用简单的方法做出来。每隔w数字就会向下转向,就比如题目上示例的w=6,无论从任何一个点出发,到6的倍数就会向下走,走6步继续向下走,我们可以使用两个变量记录,向下走的步数就是两个房子在列上的距离,行之间的距离需要进行处理,因为每两行是不同的,一行正增长,一行负增长,如果向下转向的次数是2的倍数说明又回到了相同的递增/递减规律行上,只需要取x1-x2的绝对值,x1即原坐标所在的行,x2即终点坐标所在的行;如果是转向奇数次,则说明一行正增长,一行负增长,取余之后的值一个是从左数到右,一个是从右数到左,我们直接给第一个数字加上6得到了下一个数字的位置,就变成了偶数行,再取相减的绝对值即可!

①接收数据

②模拟过程,存储转向数据

③判断转向次数,若为偶数直接取行位置相减的绝对值即可

④若不为偶数,给第一个数字+w再取相减的绝对值

⑤输出结果

代码如下👇

复制代码
	public static void main(String[] args) {
		Scanner scan = new Scanner(System.in);
		int w=scan.nextInt();
		int start=scan.nextInt();
		int end=scan.nextInt();
		int count=0;
		int x1=start%w;//距离行起点相对位置
		int x2=end%w;//距离行起点相对位置
		for (int i = start; i <= end; i++) {
			if (i%w==0) {//转向
				count++;
			}
		}
		//System.out.println(count);测试点
		if (count%2==0) {//两行同方向
			System.out.println(count+Math.abs(x1-x2));
		}else {//两个方向不同
			int x3=Math.abs(end-((count+1)*w-start+1));
			//System.out.println(x3);
			System.out.println(count+x3);
		}
		scan.close();
	}
相关推荐
猴哥源码15 分钟前
基于Java+SpringBoot的在线小说阅读平台
java·spring boot
lingRJ77715 分钟前
从混沌到掌控:基于OpenTelemetry与Prometheus构建分布式调用链监控告警体系
java·springboot·prometheus·backend·opentelemetry·jaeger·microservices
星辰离彬22 分钟前
Java 与 MySQL 性能优化:Java应用中MySQL慢SQL诊断与优化实战
java·后端·sql·mysql·性能优化
开开心心_Every44 分钟前
便捷的Office批量转PDF工具
开发语言·人工智能·r语言·pdf·c#·音视频·symfony
FirstFrost --sy1 小时前
数据结构之二叉树
c语言·数据结构·c++·算法·链表·深度优先·广度优先
森焱森2 小时前
垂起固定翼无人机介绍
c语言·单片机·算法·架构·无人机
搂鱼1145142 小时前
(倍增)洛谷 P1613 跑路/P4155 国旗计划
算法
Yingye Zhu(HPXXZYY)2 小时前
Codeforces 2021 C Those Who Are With Us
数据结构·c++·算法
程序猿小D2 小时前
[附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+jsp实现的个人财务管理系统,推荐!
java·数据库·mysql·spring·毕业论文·ssm框架·个人财务管理系统
转转技术团队3 小时前
二奢仓店的静默打印代理实现
java·后端