【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 ...
随机推荐
- shutdown - 关闭系统
总览 SYNOPSIS /sbin/shutdown [-t sec] [-arkhncfF] time [warning-message] 描述 DESCRIPTION shutdown 以一种安全 ...
- go语言从例子开始之Example13.函数多返回值
Go 内建多返回值 支持.这个特性在 Go 语言中经常被用到,例如用来同时返回一个函数的结果和错误信息. Example: package main import "fmt" // ...
- 命令 检查Linux服务器性能
一.uptime命令 这个命令可以快速查看机器的负载情况.在Linux系统中,这些数据表示等待CPU资源的进程和阻塞在不可中断IO进程(进程状态为D)的数量.这些数据可以让我们对系统资源使用有一个宏观 ...
- vs2010管理员运行
VS2010 Configuation->Linker->Manifest File->UAC Execution Level-> requireAdministrator
- Spring IOC 的理解,初始化过程
在创建ApplicationContext实例对象过程中会创建一个spring容器,该容器会读取配置文件"cn/wuliaokankan/beans.xml",并统一管理由该文件中 ...
- jenkins参数化配置,pom.xml配置
1.要实现Jenkins参数化构建,要先在代码里写好能接收该参数value的配置,在pom.xml文件里加配置,如下: 1)<properties></properties>里 ...
- Map、Filter和Reduce函数(Python)
Map map(function_to_apply, list_of_inputs) 设有以下代码: >>> items = [1, 2, 3, 4, 5] >>> ...
- gene network analysis
基因表达分析包括3个层次[68], 首先是单基因水平, 即比较对照组与实验组的每个基因是否存在表达差异, 这主要指差异基因表达分析; 其次是多基因水平, 如按照基因的共同功能.相互作用.共同表达等 ...
- Java的传值调用
(本文非引战或diss,只是说出自己的理解,欢迎摆正心态观看或探讨) 引子 之所以写这篇文章是因为前些天写了一篇<Java中真的只有值传递么?>探讨了网上关于Java只有值传递的说法,当时 ...
- legend2---17、legend2里面怎么面向对象
legend2---17.legend2里面怎么面向对象 一.总结 一句话总结: mvc本身挺优:本身mvc的开发模式,就算是面向过程下也还行,如果面向对象那就更加棒了 实体类无需属性:由于php的生 ...