每日一题(小白)模拟娱乐篇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();
	}
相关推荐
周杰伦fans1 分钟前
C#中OrderByDescending 是LINQ扩展方法之一
开发语言·c#·linq
罗湖老棍子6 分钟前
二维vector完全指南1:从定义到增删改查
数据结构·c++·算法·stl
再卷也是菜7 分钟前
C++篇(22)LRU Cache
数据结构·c++·算法
语落心生9 分钟前
海量数据集的AI自动化预测打标 -- 振动特征多标签分类
算法
语落心生13 分钟前
海量数据集AI自动化打标 - 温度周期检测
算法
李绍熹19 分钟前
Lua 语言基础教程
开发语言·junit·lua
语落心生22 分钟前
海量数据集的AI自动化预测打标 -- 矿业音频分类
算法
周杰伦fans23 分钟前
C# 中 SQL Server 数据库调优指南(小白友好版)
开发语言·数据库·c#
吃着火锅x唱着歌24 分钟前
LeetCode 3185.构成整天的下标对数目II
算法·leetcode·职场和发展
1***y17826 分钟前
PHP在微服务中的微服务开发
开发语言·微服务·php