1、给定两个正整数(二进制形式表示)A和B,问把A变为B需要改变多少位(bit)?也就是说,整数A和B的二进制表示中有多少位是不同的?(181)

解法一:举例说明,为了减少复杂度,就使用八位二进制吧。设 A = 0010 1011, B = 0110 0101.
1. C = A & B = 0010 0001;
2. D = A | B = 0110 1111;
3. E = C ^ D = 0100 1110;
4. 结果E中有4个1,那么也就是说将A变成B,需要改变4位(bit)。
至于如何判断E的二进制表示中有几个1,可以采用快速移位与方法。
算法原理如下:
1. A & B,得到的结果C中的1的位表明了A和B中相同的位都是1的位;
2. A | B, 得到的结果D中的1的位表明了A和B在该位至少有一个为1的位,包含了A 与 B 都是1的位数,
经过前两步的位运算,,C 中1的位表明了A 和 B在该位都是1,D中为0的位表明了A 和 B 在该位都是0 ,所以进行第三步。
3. C ^ D,E 中为1的位表明了A 和 B不同的位。

 class Solution {
/**
*@param a, b: Two integer
*return: An integer
*/
public static int bitSwapRequired(int a, int b) { /* int getNum(int n)
{
if(n==0)
{
return 0;
}
int count=0;
while(n)
{
n &= (n-1);
count++;
}
return count;
} */
int count = 0;
int c = a & b;
int d = a | b;
int n = c ^ d;
if(n == 0)
{
return 0;
}
while(n != 0)
{
n &= (n-1);
count++;
} return count;
} };

2.dp

 class Solution {
public:
int minPathSum(vector<vector<int>>& grid) {
//use vector to represent 2 dimension array
//hero num
int m = grid.size(), n = grid[].size();
vector<vector<int>> dp(m, <vector<int> (n));
for(int i = ; i < m; i++){
for(int j = ; j < n; j++){
if(i == ){
if(j == ){
dp[i][j] = grid[i][j];
}else{
dp[i][j] = dp[i][j-] + grid[i][j];
}
}else if(j == ){
dp[i][j] = dp[i-][j] + grid[i][j];
}else{
dp[i][j] = min(dp[i][j-], dp[i-][j]) + grid[i][j];
}
}
}
return dp[m-][n-];
}
};

3、问题描述:给定一个区间集合,合并有重叠的区间  解题思路:先对区间进行排序,按开始点进行排序,再一个一个进行合并

Total Accepted: 49133 Total Submissions: 211712 Difficulty: Hard

Given a collection of intervals, merge all overlapping intervals.

For example,
Given [1,3],[2,6],[8,10],[15,18],
return [1,6],[8,10],[15,18].

 /**
* Definition for an interval.
* public class Interval {
* int start;
* int end;
* Interval() { start = 0; end = 0; }
* Interval(int s, int e) { start = s; end = e; }
* }
*/
public class Solution {
public List<Interval> merge(List<Interval> intervals) { List<Interval> result = new ArrayList<Interval>(); if(null == intervals || intervals.size() <= 0){
return result;
} Collections.sort(intervals, new Comparator<Interval>(){
public int compare(Interval arg0, Interval arg1){
return arg0.start - arg1.start;
}
}); Interval prev = null;
for(Interval item: intervals){
if(null == prev || prev.end < item.start){
result.add(item);
prev = item;
}else if(prev.end < item.end){
prev.end = item.end;
}
} return result; }
}

附:上面采用java实现算法,其中排序使用了Collections.sort方法实现,这里研究一下对该方法实现排序的两种方法:
方法1:对列表对象实现Comparable接口

 import java.util.*;

 public class collection_sort{
public static void main(String[] args){ User user = new User();
user.setName("jack");
user.setOrder(3); User user1 = new User();
user1.setName("randy");
user1.setOrder(2); List<User> list = new ArrayList<User>();
list.add(user);
list.add(user1);
Collections.sort(list);
for(User u: list){
System.out.println(u.getName());
}
}
} class User implements Comparable<User>{
private String name;
private Integer order; public String getName(){
return name;
}
public void setName(String name){
this.name = name;
}
public Integer getOrder(){
return order;
}
public void setOrder(Integer order){
this.order = order;
} public int compareTo(User arg0){
return this.getOrder().compareTo(arg0.getOrder());
}
}

方法2:根据Collections.sort方法重载实现

 public class collection_sort{

     public static void main(String[] args){

         User user = new User();
user.setName("jack");
user.setOrder(3); User user1 = new User();
user1.setName("randy");
user1.setOrder(2); List<User> list = new ArrayList<User>();
list.add(user);
list.add(user1); Collections.sort(list, new Comparator<User>(){ public int compare(User arg0, User arg1){
return arg0.getOrder().compareTo(arg1.getOrder());
}
}); for(User u: list){
System.out.println(u.getName());
}
}
} class User{
private String name;
private Integer order; public String getName(){
return name;
}
public void setName(String name){
this.name = name;
}
public Integer getOrder(){
return order;
}
public void setOrder(Integer order){
this.order = order;
}
}

LeetCode算法题解的更多相关文章

  1. LeetCode 算法题解 js 版 (001 Two Sum)

    LeetCode 算法题解 js 版 (001 Two Sum) 两数之和 https://leetcode.com/problems/two-sum/submissions/ https://lee ...

  2. 【算法】LeetCode算法题-Merge Two Sorted List

    这是悦乐书的第148次更新,第150篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第7题(顺位题号是21).合并两个已排序的链表并将其作为新链表返回. 新链表应该通过拼接 ...

  3. 【算法】LeetCode算法题-Valid Parentheses

    这是悦乐书的第147次更新,第149篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第6题(顺位题号是20),给定一个只包含字符'(',')','{','}','['和'] ...

  4. Leetcode 简略题解 - 共567题

    Leetcode 简略题解 - 共567题     写在开头:我作为一个老实人,一向非常反感骗赞.收智商税两种行为.前几天看到不止两三位用户说自己辛苦写了干货,结果收藏数是点赞数的三倍有余,感觉自己的 ...

  5. Leetcode算法【34在排序数组中查找元素】

    在之前ARTS打卡中,我每次都把算法.英文文档.技巧都写在一个文章里,这样对我的帮助是挺大的,但是可能给读者来说,一下子有这么多的输入,还是需要长时间的消化. 那我现在改变下方式,将每一个模块细分化, ...

  6. Leetcode算法【114. 二叉树展开为链表】

    上周通过一位小伙伴,加入了一个氛围很好的小群,人不多,但是大家保持着对知识的渴望,让我很感动. 我自己也有一个群,人数也不多,但是能真正互动起来一起学习,一起进步的,还是太少.所以,现在也在学习如何让 ...

  7. ACM金牌选手讲解LeetCode算法《栈和队列的高级应用》

    大家好,我是编程熊,双非逆袭选手,字节跳动.旷视科技前员工,ACM金牌,保研985,<ACM金牌选手讲解LeetCode算法系列>作者. 上一篇文章讲解了<线性表>中的数组.链 ...

  8. ACM金牌选手讲解LeetCode算法《哈希》

    大家好,我是编程熊. 往期文章介绍了<线性表>中的数组.链表.栈.队列,以及单调栈和滑动窗口. ACM金牌选手讲解LeetCode算法<线性表> ACM金牌选手讲解LeetCo ...

  9. LeetCode OJ 题解

    博客搬至blog.csgrandeur.com,cnblogs不再更新. 新的题解会更新在新博客:http://blog.csgrandeur.com/2014/01/15/LeetCode-OJ-S ...

随机推荐

  1. ZK 代码自动提示

    1.设置xsd 打开eclipse,Window-Preference,进行如下设置: 2.创建zul文件 (1)打开File—New—Other窗口,新建XML File文件: (2)选择新建文件所 ...

  2. Uncaught SyntaxError: Unexpected token ILLEGAL

    原因,相关的JS函数中,存在一个中文逗号,修改即可正常执行

  3. 定位position

    position : absolute | relative | fixed | static 定位:子集可以超出父级的范围,如父级蛇overflow:hidden则看不到. absolute : 绝 ...

  4. Unity3d优化

    检测方式: 一,Unity3D 渲染统计窗口 Game视窗的Stats去查看渲染统计的信息: 1.FPS fps其实就是 frames per second,也就是每一秒游戏执行的帧数,这个数值越小, ...

  5. Otsu algorithm

    一.介绍 OTSU算法也称最大类间差法,有时也称之为大津算法,被认为是图像分割中阈值选取的最佳算法,计算简单,不受图像亮度和对比度的影响,因此在数字图像处理上得到了广泛的应用.它是按图像的灰度特性,将 ...

  6. PHP运算符===和==的区别 小细节

    区别: ===是恒等计算符   同时检查表达式的值与类型 ==是比较运算符号  不会检查条件式的表达式的类型 举例 if (strstr($new_url,'http://') === false) ...

  7. Java学习-001-JDK安装配置

    本节主要讲述在 Win7 64bit 系统下安装.配置 JDK8u25,敬请参阅.详细步骤如下: 一.JDK下载 您可到 官方网站 或 我的云盘 下载,对应的JDK8u25的安装程序,下载过程不再赘述 ...

  8. spring记录

    context:property-placeholder 是将properties加载到Spring上下文中,接下来在定义bean的时候就能用${xx.xx}来访问了. util:properties ...

  9. VS2012+Win7网站发布详细步骤

    VS2012+Win7网站发布详细步骤 本机环境: 本文分三个部分介绍Web项目发布的常规方法,大神级别可以略过,主要是为了方便一些初学者. 第一部分:VS2012把项目发布到文件系统. 第二部分:I ...

  10. java多态性

    多态分两种: (1)   编译时多态(设计时多态):方法重载. (2)   运行时多态:JAVA运行时系统根据调用该方法的实例的类型来决定选择调用哪个方法则被称为运行时多态.(我们平时说得多的事运行时 ...