【华为OD题库-047】求最小步数-java

题目

求从坐标零点到坐标点n的最小步数,一次只能沿横坐标轴向左或向右移动2或3.

注意:途径的坐标点可以为负数
输入描述

坐标点n
输出描述

输出从坐标零点移动到坐标点n的最小步数
备注

1<= n <= 10^9
示例1:
输入

4
输出

2
说明

从坐标零点移动到4,最小需要两步,即右移2,再右移2

思路

两种方案:

1. 动态规划

n=1,至少需要两步:3 -2

n=2, 只需移动一步:2

n=3, 只需移动1步:3

记dp[n]为n的最小步数

那么对于n>=4时,dp[n]=min(dp[n-3],dp[n-2])+1。

可以用一个队列来模拟实现这个过程

2. 数学

要想步数最小,考虑优先走3步,对于任意大于1的正整数n:记a=n/3;b=a%3

如果b == 0,那么只需要走a步即可(即全走3步)

如果b == 2,那么只需要走a+1步(a个3步,1个2步)

如果b == 1,那么需要走a-1+2=a+1步,(a-1个3步,2个2步)

题解

java 复制代码
package hwod;

import java.util.LinkedList;
import java.util.Scanner;

public class TheMinStep {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        System.out.println(minStep(n));

    }
//动态规划
    private static int minStep(int n) {
        if (n == 1) return 2;
        LinkedList<Integer> queue = new LinkedList<>();
        queue.addLast(2);
        queue.addLast(1);
        queue.addLast(1);
        for (int i = 4; i <= n; i++) {
            int first = queue.pollFirst();
            int second = queue.peekFirst();
            queue.addLast(Math.min(first, second) + 1);
        }
        return queue.peekLast();
    }
// 数学解法
    private static int minStep2(int n) {
        if (n == 1) return 2;
        int a = n / 3, b = n % 3;
        if (b == 0) return a;
        return a + 1;
    }
}

推荐

如果你对本系列的其他题目感兴趣,可以参考华为OD机试真题及题解(JAVA),查看当前专栏更新的所有题目。

相关推荐
言慢行善29 分钟前
sqlserver模糊查询问题
java·数据库·sqlserver
专吃海绵宝宝菠萝屋的派大星35 分钟前
使用Dify对接自己开发的mcp
java·服务器·前端
大数据新鸟1 小时前
操作系统之虚拟内存
java·服务器·网络
Tong Z1 小时前
常见的限流算法和实现原理
java·开发语言
凭君语未可1 小时前
Java 中的实现类是什么
java·开发语言
He少年1 小时前
【基础知识、Skill、Rules和MCP案例介绍】
java·前端·python
克里斯蒂亚诺更新1 小时前
myeclipse的pojie
java·ide·myeclipse
迷藏4941 小时前
**eBPF实战进阶:从零构建网络流量监控与过滤系统**在现代云原生架构中,**网络可观测性**和**安全隔离**已成为
java·网络·python·云原生·架构
迷藏4941 小时前
**发散创新:基于Solid协议的Web3.0去中心化身份认证系统实战解析**在Web3.
java·python·web3·去中心化·区块链
qq_433502182 小时前
Codex cli 飞书文档创建进阶实用命令 + Skill 创建&使用 小白完整教程
java·前端·飞书