#198 House Robber

You are a professional robber planning to rob houses along a street. Each house has a certain amount of money stashed, the only constraint stopping you from robbing each of them is that adjacent houses have security system connected and it
will automatically contact the police if two adjacent houses were broken into on the same night.

Given a list of non-negative integers representing the amount of money of each house, determine the maximum amount of money you can rob tonight without alerting the police.

去掉故事背景就是说,一个含有n个元素的数组(元素值当然大于0),从中取出m个位置的元素,要求相邻两个位置的元素最多仅仅能取一个。

求能获得元素值和的最大值

典型的DP问题。

自顶向下分析问题。n个元素的数组取和的最大值  f(n) ,能够转换为

max{  f(n-1) , f(n-2)+nums[n]  }

利用数组a[n]保存中间子问题结果,算法例如以下:

注:依据故事背景。一条街上的住户不超过1000家吧。。。

//0ms
int rob(int* nums, int numsSize) {
int i=0,t1,t2;
int a[1000]={0};
if(numsSize==1)
{
a[0] = nums[0];
return a[0];
}
if(numsSize==2)
{
a[1] = (nums[0]>=nums[1]) ? nums[0]:nums[1];
return a[1];
}
if(numsSize==3)
{
if(nums[0]+nums[2]>=nums[1])
a[3] = nums[0]+nums[2];
else
a[3] = nums[1];
return a[3];
}
if(numsSize>3)
{
a[0] = nums[0];
a[1] = (nums[0]>=nums[1]) ? nums[0]:nums[1];
if(nums[0]+nums[2]>=nums[1])
a[2] = nums[0]+nums[2];
else
a[2] = nums[1]; for(i=3;i<numsSize;i++)
{
//t1 = rob(nums,numsSize-1);
//t2 = rob(nums,numsSize-2)+nums[numsSize-1];
t1 = a[i-1];
t2 = a[i-2]+nums[i];
a[i] = (t1>=t2)? t1:t2;
}
}
return a[numsSize-1];
}

# 202 Happy Number

Write an algorithm to determine if a number is "happy".

A happy number is a number defined by the following process: Starting with any positive integer, replace the number by the sum of the squares of its digits, and repeat the process until the number equals 1 (where it will stay), or it loops endlessly in a cycle
which does not include 1. Those numbers for which this process ends in 1 are happy numbers.

Example: 19 is a happy number

  • 12 + 92 = 82
  • 82 + 22 = 68
  • 62 + 82 = 100
  • 12 + 02 + 02 =
    1

Happy Number  指的是数n的每一位的平方和能通过经过有限次循环后和为 1

仅仅要出现循环就不是Happy Number

对于int型(10位)每一位平方和 小于: 9^2  * 10  = 810 ;能够用一个数组保存和 ,当再次出现该值时说明出现了一个循环,返回false

//0ms
bool isHappy(int n) {
int hash[810]={0};
int i=1,new_n=0;
if(n==1)
return true;
while(n!=1)
{
new_n = 0;
while(n)
{
new_n += (n%10)*(n%10);
n = n/10;
}
n = new_n; if(n==1)
return true; if(hash[n]==1)
return false;
else
hash[n] = 1;
}
}

基于事实1 是 Happy Number 而 2,3,4,5,6均不是Happy Number  为了使空间复杂度变为为O(1),可採用例如以下算法

//0ms
bool isHappy(int n)
{
int next;
while(n > 6)
{
next = 0;
while(n)
{
next += (n%10) * (n%10);
n /= 10;
}
n = next;
}
return n == 1;
}

#203 Remove Linked List Elements

Remove all elements from a linked list of integers that have value val.

Example

Given: 1 --> 2 --> 6 --> 3 --> 4 --> 5 --> 6, val = 6

Return: 1 --> 2 --> 3 --> 4 --> 5

<span style="font-size:10px;">//12ms
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* struct ListNode *next;
* };
*/
struct ListNode* removeElements(struct ListNode* head, int val) {
struct ListNode *newhead,*p,*q;
if(!head)
return NULL;
newhead->next = head; //简化代码,加入头结点 q p
q = newhead;
p = head;
while(p)
{
if(p->val==val)
q->next = p->next;//q 不变 p后移
else
q = p;// q p 都后移
p = p->next;
}
return newhead->next;
}</span>

#204 Count Primes

Count
the number of prime numbers less than a non-negative number, n.

求1~n-1之间素数的个数,注意1不是素数

推断 n 是一个素数的方法是,不能被
2 ~ sqrt(n) 之间的数整除。即约数仅仅有1和其本身

在Leetcode Discuss中看到例如以下解法:时间和空间复杂度都接近O(n)

https://leetcode.com/discuss/34622/my-c-solutions-in-44ms-time-nearly-o-n-and-space-nearly-o-n

//44ms
/*1. trick1 is to use square root of n.
2. trick2 is not to use non-prime numbers as the step
3. trick3 is to use i*i as the start.
4. trick4 is to use count-- in every loop, avoiding another traversal. */
int countPrimes(int n) {
if(n <= 2) return 0;
if(n == 3) return 1;
bool *prime= (bool*)malloc(sizeof(bool)*n);
int i=0,j=0;
int count = n-2;
int rt = sqrt(n);//trick1
for(j = 0; j < n; j++)
{
prime[j] = 1;
}
for(i = 2; i <= rt; i++)
{
if (prime[i])//trick2
{
for(j=i*i ; j<n ; j+=i)//trick3
{
if (prime[j])
{
prime[j]=0;
count--;//trick4
}
}
}
}
free(prime);
return count;
}

Leetcode--easy系列9的更多相关文章

  1. hdu 2049 不easy系列之(4)——考新郎

    不easy系列之(4)--考新郎 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  2. LeetCode——single-number系列

    LeetCode--single-number系列 Question 1 Given an array of integers, every element appears twice except ...

  3. HDU 2045不easy系列之三LELE的RPG难题(趋向于DP的递推)

    不easy系列之(3)-- LELE的RPG难题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Ot ...

  4. hdu1465不easy系列之中的一个(错排)

    版权声明:本文为博主原创文章,未经博主同意不得转载. vasttian https://blog.csdn.net/u012860063/article/details/37512659 转载请注明出 ...

  5. Leetcode算法系列(链表)之删除链表倒数第N个节点

    Leetcode算法系列(链表)之删除链表倒数第N个节点 难度:中等给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点.示例:给定一个链表: 1->2->3->4-&g ...

  6. Leetcode算法系列(链表)之两数相加

    Leetcode算法系列(链表)之两数相加 难度:中等给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字.如果,我们将 ...

  7. leetcode easy problem set

     *勿以浮沙筑高台* 持续更新........     题目网址:https://leetcode.com/problemset/all/?difficulty=Easy 1. Two Sum [4m ...

  8. [Leetcode] Sum 系列

    Sum 系列题解 Two Sum题解 题目来源:https://leetcode.com/problems/two-sum/description/ Description Given an arra ...

  9. LeetCode 笔记系列16.3 Minimum Window Substring [从O(N*M), O(NlogM)到O(N),人生就是一场不停的战斗]

    题目:Given a string S and a string T, find the minimum window in S which will contain all the characte ...

  10. 决战Leetcode: easy part(51-96)

    本博客是个人原创的针对leetcode上的problem的解法,所有solution都基本通过了leetcode的官方Judging,个别未通过的例外情况会在相应部分作特别说明. 欢迎互相交流! em ...

随机推荐

  1. Hadoop2.9.1安装教程_环境Ubuntu_VMware安装

    一,环境选择 Hadoop需要运行在linux系统之下,所以有以下两种选择:1,安装双系统,缺点:此方式比较麻烦而且并不适合初学者,因为之后的安装以及配置过程可能会遇到许多问题,这需要我们上网去搜索. ...

  2. Uboot优美代码赏析1:目录结构和malkefile分析

    Uboot优美代码赏析1:目录结构和malkefile分析 关于Uboot自己选的版本是目前最新的2011.06,官方网址为:http://www.denx.de/wiki/U-Boot/WebHom ...

  3. webpack中关于require与import的区别

    1.require常见使用场景: var path = require('path') var utils = require('./utils') 此时webpack会将path/utils/con ...

  4. (56) 解决字段设为readonly无法保存

    问题描述:当一个字段设为readonly =True 后,在form表单,即使你用onchange方法改变了值但也不能保存到数据库当时.平时在这样的要求,form表单有些字段要展示给用户,但又要达到不 ...

  5. where和having

    where可以不能使用别名作为过滤条件,而having可以使用别名作为过滤条件. 在ORACLE中,select 语句的执行顺序是: 1. from语句 2. where语句(结合条件) 3. sta ...

  6. 数据库ifnull方法

    IFNULL(expr1,expr2)如果expr1不是NULL,IFNULL()返回expr1,否则它返回expr2.IFNULL()返回一个数字或字符串值.例如: ifnull() 如果sum(t ...

  7. CSS学习(三)

    CSS 分组 和 嵌套 选择器 分组选择器 h1,h2,p { color:green; } 嵌套选择器 <!DOCTYPE html> <html> <head> ...

  8. POJ 1306

    其实求的这个数的式子化简一下,就是C(N,M)..... #include <iostream> #include <algorithm> #include <cstdi ...

  9. Oracle_角色_权限具体说明

    一.Oracle内置角色connect与resource的权限 grant connect,resource to user;  CONNECT角色: --是授予终于用户的典型权利,最主要的  ALT ...

  10. 输入password登录到主界面,录入学生编号,排序后输出

    n 题目:输入password登录到主界面,录入学生编号,排序后输出 n 1.  语言和环境 A.实现语言 C语言 B.环境要求 VC++ 6.0 n 2.  要求 请编写一个C语言程序.将若干学生编 ...