位运算:

左移:m<<n将m左移n位,左移后低位补充0;

右移:m>>n将m右移n位,右移后高位补充的是符号位,负数补充1,整数补充0.(正数的边界值为(1,ox7FFFFFFF),负数的边界值为(ox80000000,oxFFFFFFFF))

题目一:请实现一个函数,输入一个整数,输出这个数的二进制表示中1的个数。

思路一:将二进制数i与1相与,判断是否为1,然后将tag=1左移一位得到tag=2,然后再与i相与,循环结束的条件是tag==0;该算法的时间复杂度为输入的i的位数。

#include <iostream>
using namespace std;
int numberOf1(int n)
{
int count=0;
int tag=1;
while(tag)
{
if(tag&n)
count++;
tag=tag<<1;
}
return count;
} void main()
{ int i;
while(cin>>i)
{
cout<<numberOf1(i)<<endl;
}
}

思路二:把一个整数n减去1,再和原来的整数与运算,会把该整数的最右边的1变成0,那么,一个整数的二进制中有多少个1,就可以进行多少次这样的操作。循环结束的条件是n为0;

#include <iostream>
using namespace std;
int numberOf1(int n)
{
int count=0; while(n)
{
++count;
n=(n-1)&n;
}
return count;
} void main()
{ int i;
while(cin>>i)
{
cout<<numberOf1(i)<<endl;
}
}

Java代码:

public class ByteCompute {
public int byteCompute(int n){
int tag=1;
int count=0;
while(tag!=0){//由于int类型的函数是32位因此要循环32次
if((n&tag)!=0)
count++;
tag=tag<<1; }
return count;
}
public int byteCompute1(int n){
int count=0;
while(n!=0){//由于每次n和n-1相与都会导致,n的最右边的为1的元素变成0,因此总共要循环的次数就是1的个数次。
count++;
n=(n-1)&n;
}
return count;
} public static void main(String[] args){
int n=3;
ByteCompute bc=new ByteCompute();
int count=bc.byteCompute(n);
int count1=bc.byteCompute1(n);
System.out.println(count+" "+count1);
}
}

题目二:用一条语句判断一个整数是不是2的整数次方。

思路:一个整数如果是2的整数次方,那么它的二进制表示中有且仅有一个位是1,而其他所有位都是0,根据上面的分析,把这个整数减去1后再与自己相与,唯一的1也会变成0.

题目三:输入两个整数m和n,计算需要改变n的几位可以得到m。

第一步先将这m和n异或,然后再数1的个数。

题目四:在Excel2003中,用A表示第一列,用B表示第二列,用C表示第三列....用z表示第26列,AA表示第27列,用AB表示第28列.....依次类推,请写一个函数输入字母表 示列号,输出是第几列。(十进制转换为26进制的问题)

思路:写一个函数返回值为整型,如果输入的字符串s为空则返回空,定义并初始化一个最终的返回值sum=0,设置一个行动下标i,当i满足小s.length()时,定义一个临时的整型变量temp=s[i]-'A'用来存放单个位置上的由字符变成的数字。只有当temp是在0~26的范围之间的时候才有sum=sum*26+temp+1.

#include<iostream>
#include<string>
#include<sstream>
using namespace std;
int StringToInt(const string& str)
{
int length = str.length();//这里也可用str.size(). if(length < )//如果没有输入字符,则报错。
{
cout << "Invalid input" << endl;
return -;
} int sum = ;//如果输入的字符为空字符,输出为0. for(int i = ; i < length; i++)
{
int temp = str[i] - 'A';
if(temp >= || temp < )
{
cout << "Invalid input" << endl;
return -;
}
sum = *sum + temp + ;
}
return sum; }
int main()
{
string str;
while(getline(cin,str))//这里如果用cin >> str,不能输入空的字符串。
cout << StringToInt(str)<<endl;
return ;
}

java代码:

public class StringToInt {
public int stringToInt(String str){
int len=str.length();
if(len<0)
throw new RuntimeException("inVaild input!");
int sum=0;//输入为空的时候,输出0;
for(int i=0;i<len;i++){
int temp=str.charAt(i)-'A';
if(temp<26&&temp>=0)
sum=26*sum+temp+1;
}
return sum;
}
public static void main(String[] args){
String str="AAZ";
StringToInt sti=new StringToInt();
int sum=sti.stringToInt(str);
System.out.println(sum+" ");
}
}

剑指offer—算法之位运算(二进制中1的个数)的更多相关文章

  1. 剑指Offer面试题:9.二进制中1的个数

    一.题目:二进制中1的个数 题目:请实现一个函数,输入一个整数,输出该数二进制表示中1的个数.例如把9表示成二进制是1001,有2位是1.因此如果输入9,该函数输出2. 二.可能引起死循环的解法 一个 ...

  2. 剑指Offer面试题:8.二进制中1的个数

    一 题目:二进制中1的个数 题目:请实现一个整数,输出该数二进制表示中1的个数.例如把9表示成二进制是1001,有2位是1.因此如果输入9,该函数输出2. 二 可能引起死循环的解法 // 计算整数的二 ...

  3. 《剑指offer》面试题10 二进制中1的个数 Java版

    书中方法一:对于每一位,用1求与,如果为1表明该位为1.一共要进行32次,int4字节32位. public int check(int a){ int result = 0; int judge = ...

  4. 《剑指offer》面试题15. 二进制中1的个数

    问题描述 请实现一个函数,输入一个整数,输出该数二进制表示中 1 的个数.例如,把 9 表示成二进制是 1001,有 2 位是 1.因此,如果输入 9,则该函数输出 2. 示例 1: 输入:00000 ...

  5. 剑指Offer(书):二进制中1的个数

    题目:输入一个整数,输出该数二进制表示中1的个数.其中负数用补码表示. 分析:下面这两种方法都可以,不过第二种更好一些. public int numberOf1(int n) { int count ...

  6. 剑指offer算法_位运算求和

    不用+,-,*,/运算求和,可以分成三步: 1.计算两个数字的异或值,相当于只计算每一位的和,不计算进位,得出结果sum: 2.计算两个数字的与值,相当于求出两个数字的进位,然后左移一位,相当于进位, ...

  7. 剑指offer 11. 位运算 二进制中1的个数

    题目描述 输入一个整数,输出该数二进制表示中1的个数.其中负数用补码表示.   //思想:用1(1自身左移运算,其实后来就不是1了)和n的每位进行位与,来判断1的个数     private stat ...

  8. 剑指offer编程题Java实现——面试题10二进制中1的个数

    题目: 请实现一个函数,输入一个整数,输出该整数二进制表示中1的个数.例如,把9表示成二进制是1001,有2位是1,该函数输出2解法:把整数减一和原来的数做与运算,会把该整数二进制表示中的最低位的1变 ...

  9. 剑指offer算法总结

    剑指offer算法学习总结 节选剑指offer比较经典和巧妙的一些题目,以便复习使用.一部分题目给出了完整代码,一部分题目比较简单直接给出思路.但是不保证我说的思路都是正确的,个人对算法也不是特别在行 ...

随机推荐

  1. __stdcall 与 __cdecl

    (1) _stdcall调用 _stdcall是Pascal程序的缺省调用方式,参数采用从右到左的压栈方式,被调函数自身在返回前清空堆栈. WIN32 Api都采用_stdcall调用方式,这样的宏定 ...

  2. 【LA3942-Remember the word 】Trie

    http://acm.hust.edu.cn/vjudge/problem/22109 题意:给定n个单词,一个字符串,问把这个字符串划分为若干个单词的连接(单词可重复使用)有多少种方案(mod200 ...

  3. win32空项目创建窗体

    #include "stdafx.h" //窗口过程函数(系统自动调用,即回调函数)LRESULT WINAPI MsgProc(HWND hWnd,UINT msg,WPARAM ...

  4. 一个简单的ObjC和JavaScript交互工具

    https://github.com/changjianfeishui/XBWebBridge ObjectiveC与Js交互是常见的需求,可对于新手或者所谓的高手而言,其实并不是那么简单明了.这里只 ...

  5. 虚拟机WindowServer2003共享文件夹

    前话 之前我写过虚拟机装SQL Server的博文,也许有同学参考了也通过虚拟机装数据库服务来做实验作业了. 到了第二章节学习时,实验要求数据库导出Excel文件,这样一来就出现了小问题了,Windo ...

  6. 【重走Android之路】【Java面向对象基础(一)】数据类型与运算符

    [重走Android之路][基础篇(一)][Java面向对象基础]数据类型与运算符   1.数据类型介绍 在Java中,数据类型分为两种:基本数据类型和引用类型. 基本数据类型共8种,见下表: 基本数 ...

  7. Android 怎么使用Bitmap+Canvas 自适应屏幕

    我们可以使用Matrix 来放缩我们得到的Bitmap 从而使我们的BItmap适应我们的手机屏幕 首先我们得先获取我们的手机屏幕的大小 WindowManager wm = (WindowManag ...

  8. intelliJ IDEA中项目以jar包的形式导出

    在上一篇中把intelliJ IDEA安装并配置完事后,我们就可以写scala程序了.编写完scala程序后我们要把程序导出,上传到服务器上,在spark集群下运行,下面就讲一下包的导出过程以及包在服 ...

  9. Oracle ->> Oracle下查看实际执行计划的方法

    也许有很多种方法,这里只是书上学到的一种方法 with a as ( order by grp_factor) t ) select b.id, a.grp_factor )b --use v$sql ...

  10. PHP 对象及其三大特性

    //面向过程 //类和对象 //对象:任何东西都可以成为对象,类实例化出来的东西 //类:对所有同类的对象抽象出来的东西 //info:code,name,sex,nation,birthday // ...