Ugly Number II

[leetcode]Ugly Number

链接:https://leetcode.com/problems/ugly-number/description/

Question

Write a program to find the n-th ugly number.

Ugly numbers are positive numbers whose prime factors only include 2, 3, 5.

Example

Input: n = 10
Output: 12
Explanation: 1, 2, 3, 4, 5, 6, 8, 9, 10, 12 is the sequence of the first 10 ugly numbers.

Note:  

1 is typically treated as an ugly number.
n does not exceed 1690.

Solution

class Solution {
public:
  typedef long long int ll;
  int nthUglyNumber(int n) {
    // i2指向的位置专门乘以2,i3专门乘以3,i5专门乘以5
    int i2, i3, i5;
    i2 = i3 = i5 = 0;
    vector<int> ugly;
    ugly.resize(n);
    ugly[0] = 1;
    ll next_2 = 2;
    ll next_3 = 3;
    ll next_5 = 5;
    for (int i = 1; i < n; i++) {
      ll next_min = min(next_2, next_3);
      next_min = min(next_min, next_5);
      ugly[i] = next_min;
      // 可能会出现一个两个同时最小值,但是这样也没关系
      if (next_min == next_2) {
        i2 += 1;
        next_2 = ugly[i2]*2;
      }
      if (next_min == next_3) {
        i3 += 1;
        next_3 = ugly[i3]*3;
      }
      if (next_min == next_5) {
        i5 += 1;
        next_5 = ugly[i5]*5;
      }
    }
    return ugly[n-1];
  }
};

思路:维护三个数,分别只能乘以2,3,5,每次拿最小的数【允许多个同时最小】,然后进行进一步的更新。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值