【LeetCode】Math
[263] Ugly Number [Easy]
一个数的质因子只有2,3,5就叫丑数,写个函数判断丑数。
//Author: Wanying
//注意 0 和 1 的corner case, 你居然还没一次AC==
//想好了再写,不然等着挂吧==!!!!!
class Solution {
public:
bool isUgly(int num) {
if (num == || num == ) {
return num;
}
while(num % == ) {
num = num / ;
}
while(num % == ) {
num = num / ;
}
while(num % == ) {
num = num / ;
}
return num == ;
}
};
[264] Ugly Number II [Medium]
第一个丑数是1,返回第n个丑数是多少。
思路:dp, 第u个丑数一定是 min(vec[idx2]*2, vec[idx3]*3, vec[idx5] *5) || 所以,要存idx2,idx3,idx5, 而且vec里面不能有重复的丑数.
//Author: Wanying
//DP: idx2, idx3, idx5 class Solution {
public:
int nthUglyNumber(int n) {
vector<int> vec(,);
int idx2 = , idx3 = , idx5 = ;
for(size_t i = ; i <= n; ++i) {
int v2 = vec[idx2] * , v3 = vec[idx3] * , v5 = vec[idx5] * ;
int ith = min(v2, min(v3, v5));
if (ith == v2) {
idx2++;
}
if (ith == v3) {
idx3++;
}
if (ith == v5) {
idx5++;
}
vec.push_back(ith);
}
return vec[n-];
}
};
[313] Super Ugly Number [Medium]
跟Ugly Number II类似, 变化在于质因子不是[2,3,5]了,变成了透传进来的数组。 所以思路就从用3个idx变成了用一个数组的idx,其他一样,注意bug-free.
//Author: Wanying
class Solution {
public:
int nthSuperUglyNumber(int n, vector<int>& primes) {
vector<int> idx(primes.size(), );
vector<int> ans(, );
for (size_t i = ; i <= n; ++i) {
int ith = INT_MAX;
for (int j = ; j < primes.size(); ++j) {
int tmp = ans[idx[j]] * primes[j];
ith = min(tmp, ith);
}
for (int j = ; j < primes.size(); ++j) {
int tmp = ans[idx[j]] * primes[j];
if (ith == tmp) {
idx[j] ++;
}
}
ans.push_back(ith);
}
return ans[n-];
}
};
[172] Factorial Trailing Zeroes [Easy]
给定一个数n, 求出n!中结尾0的个数。
考虑到造成结尾0的,只有5*2的倍数, 或者直接10, 100这种,所以,我们就用 n/5 得到n中5的个数,但是可能还有25,125这种含有不止一个5的情况,所以公式如下:
ans = n/5 + n/25 + n/125 + ......
n/5 是移除所有单个的5, n/25是移除多余的5, 同理.....
/*
* Author: Wanying
* Language: C++
* Date: 2017/03/11
* 考虑到25, 125 这种数字中不止一个5, 所以公式如下: ans = n/5 + n/25 + n/125 + ......
* n/5 是移除所有单个的5, n/25是移除多余的5, 同理.....
*/
class Solution {
public:
int trailingZeroes(int n) {
int ans = ;
long long x = ; //x一直乘5, int会溢出
while (n >= x) {
ans += n / x;
x *= ;
//cout << x << " ";
}
return ans;
}
};
[166] Fraction to Recurring Decimal [Medium]
给两个数,分别代表分子,分母,求小数的表示形式,可能有循环节
- Given numerator = 1, denominator = 2, return "0.5".
- Given numerator = 2, denominator = 1, return "2".
- Given numerator = 2, denominator = 3, return "0.(6)".
模拟竖式除法, 用个map记录循环节,还是不懂的话,自己在草稿纸上写个 3/444 你就懂了 :)
注意corner case, int可能越界, 全用long long 表示
/*
* author: Wanying
* Date: 2017/03/11
* 思路就是模拟竖式除法,用个map记录循环节
* company: google
*/ class Solution {
public:
string fractionToDecimal(int numerator, int denominator) {
long long n = numerator, d = denominator; //不能用int, corner case: n = INT_MIN, d = -1; 除完了越界
string ans = "";
if (n == ) return "";
if (n < ^ d < ) {
ans += "-";
}
n = abs(n), d = abs(d);
ans += to_string(n/d);
//能整除直接返回整数部分
if (n % d == ) {
return ans;
}
ans += ".";
long long r = (n % d); // 余数也要用 long long, 不然(-1, -2147483648) 这组会溢出
map<int, int> mp; //模拟竖式除法,找循环节
while (r) {
if (mp.count(r) > ) {
ans.insert(mp[r], "(");
ans += ")";
break;
}
mp[r] = ans.size();
cout << r << " ";
r *= ;
ans += to_string(r/d);
r = r % d;
}
return ans;
}
};
【LeetCode】Math的更多相关文章
- 【LeetCode】Minimum Depth of Binary Tree 二叉树的最小深度 java
[LeetCode]Minimum Depth of Binary Tree Given a binary tree, find its minimum depth. The minimum dept ...
- 53. Maximum Subarray【leetcode】
53. Maximum Subarray[leetcode] Find the contiguous subarray within an array (containing at least one ...
- 【LeetCode】746. 使用最小花费爬楼梯
使用最小花费爬楼梯 数组的每个索引做为一个阶梯,第 i个阶梯对应着一个非负数的体力花费值 cost[i](索引从0开始). 每当你爬上一个阶梯你都要花费对应的体力花费值,然后你可以选择继续爬一个阶梯或 ...
- 【LeetCode】714、买卖股票的最佳时机含手续费
Best Time to Buy and Sell Stock with Transaction Fee 题目等级:Medium 题目描述: Your are given an array of in ...
- 【leetcode】963. Minimum Area Rectangle II
题目如下: Given a set of points in the xy-plane, determine the minimum area of any rectangle formed from ...
- 【Leetcode】104. 二叉树的最大深度
题目 给定一个二叉树,找出其最大深度. 二叉树的深度为根节点到最远叶子节点的最长路径上的节点数. 说明: 叶子节点是指没有子节点的节点. 示例:给定二叉树 [3,9,20,null,null,15,7 ...
- 【LeetCode】319. Bulb Switcher 解题报告(Python)
[LeetCode]319. Bulb Switcher 解题报告(Python) 标签(空格分隔): LeetCode 题目地址:https://leetcode.com/problems/bulb ...
- 【Leetcode】Pascal's Triangle II
Given an index k, return the kth row of the Pascal's triangle. For example, given k = 3, Return [1,3 ...
- 27. Remove Element【leetcode】
27. Remove Element[leetcode] Given an array and a value, remove all instances of that value in place ...
随机推荐
- noip2010机器翻译
以下题面摘自洛谷1540 题目背景 小晨的电脑上安装了一个机器翻译软件,他经常用这个软件来翻译英语文章. 题目描述 这个翻译软件的原理很简单,它只是从头到尾,依次将每个英文单词用对应的中文含义来替换. ...
- Android开发中怎样用多进程、用多进程的好处、多进程的缺陷、解决方法(转)
转自:http://blog.csdn.net/spencer_hale/article/details/54968092 1.怎样用多进程 Android多进程概念:一般情况下,一个应用程序就是一个 ...
- Java网络编程:IP地址和端口号
1)IP地址 用来标志网络中的一个通信实体的地址.通信实体可以是计算机,路由器等. 2)IP地址分类 IPV4:32位地址,以点分十进制表示,如192.168.0.1 IPV6:128位(16个字节) ...
- jquery 选项卡切换
html <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <ti ...
- python数组的复制问题
1.a=[2,3,4,5] b=a 只是将b指向a,对b的操作会影响a 2.如果需要对b操作,不影响a b=a[:]
- PHP浮点精度问题
使用php+ - * /计算浮点数的时候,可能会遇到一些计算结果错误的问题,如下: <?php echo intval(0.58 * 100); //输出57 解决办法 <?php ech ...
- html2canvas截图白边显示问题
html2canvas(document.getElementById('resource_chart'),{ useCORS:true, logging:false, width:$('#resou ...
- Name your feature branches by convention
https://docs.microsoft.com/en-us/azure/devops/repos/git/git-branching-guidance?view=azure-devops Nam ...
- STemWin5.22移植笔记(flyheart)
看了野火ISO开发板移植的emWin,感觉不错,但是没有写移植教程,通过摸索与百度知道了移植的过程!下面和大家分享一下 emWin是segger公司出的一款图形化界面,非常好看,大家所熟悉的ucGUI ...
- c/c++ int 范围的原因
在C语言中, signed char 类型的范围为-128~127,每本教科书上也这么写,但是没有哪一本书上(包括老师)也不会给你为什么是-128~127,这个问题貌似看起来也很简单容易, 以至于不用 ...