【华为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),查看当前专栏更新的所有题目。

相关推荐
亓才孓34 分钟前
[SpringBoot]UnableToConnectException : Public Key Retrieval is not allowed
java·数据库·spring boot
嵌入式×边缘AI:打怪升级日志43 分钟前
编写Bootloader实现下载功能
java·前端·网络
wuqingshun3141591 小时前
什么是浅拷贝,什么是深拷贝,如何实现深拷贝?
java·开发语言·jvm
Stringzhua1 小时前
队列-优先队列【Queue3】
java·数据结构·队列
ShiJiuD6668889992 小时前
Java stream流和方法引用
java·开发语言
专注前端30年2 小时前
【Java微服务架构】Spring Cloud Alibaba全家桶实战:Nacos+Sentinel+Seata+分布式事务
java·微服务·架构
苏渡苇2 小时前
轻量化AI落地:Java + Spring Boot 实现设备异常预判
java·人工智能·spring boot·后端·网络协议·tcp/ip·spring
追随者永远是胜利者3 小时前
(LeetCode-Hot100)64. 最小路径和
java·算法·leetcode·职场和发展·go
学习是生活的调味剂3 小时前
nacos原理之服务注册浅析
java·开发语言·nacos·注册中心
没有bug.的程序员4 小时前
Arthas 深度进阶:线上问题非侵入式诊断内核、方法级监控与线程阻塞排查实战指南
java·arthas·线上问题·非侵入式·方法级监控·线程阻塞