C++求1到n中1出现的次数以及数的二进制表示中1的个数

 更新时间:2016年02月15日 16:16:11   作者:Zhang_H  
这篇文章主要介绍了C++求1到n中1出现的次数以及数的二进制表示中1的个数,两道基础的算法题目,文中也给出了解题思路,需要的朋友可以参考下

在从 1 到 n 的正数中 1 出现的次数

题目:

输入一个整数 n,求从 1 到 n 这 n 个整数的十进制表示中 1 出现的次数。

例如输入 12,从 1 到 12 这些整数中包含 1  的数字有 1, 10, 1 1 和 12, 1 一共出现了 5 次

代码实现(GCC编译通过):

#include "stdio.h"
#include "stdlib.h"
 
int count1(int n);
int count2(int n);
 
int main(void)
{
  int x;
 
  printf("输入一个数:");
  scanf("%d",&x);
  printf("\n从0到%d一共遇到%d(%d)个1\n",x,count1(x),count2(x));
   
  return 0;
}
 
//解法一
int count1(int n)
{
  int count = 0;
  int i,t;
   
  //遍历1到n
  for(i=1;i<=n;i++)
  {
    t=i;
    //依次处理当前遍历到的数字的各个位
    while(t != 0)
    {
        //若为1则统计加一
      count += (t%10 == 1)?1:0;
      t/=10;
    }
  }
   
  return count;
}
 
//解法二:
int count2(int n)
{
  int count = 0;//统计变量
  int factor = 1;//分解因子
  int lower = 0;//当前处理位的所有低位
  int higher = 0;//当前处理位的所有高位
  int curr =0;//当前处理位
   
  while(n/factor != 0)
  {
    lower = n - n/factor*factor;//求得低位
    curr = (n/factor)%10;//求当前位
    higher = n/(factor*10);//求高位
     
    switch(curr)
    {
      case 0:
        count += higher * factor;
        break;
      case 1:
        count += higher * factor + lower + 1;
        break;
      default:
        count += (higher+1)*factor;
    }
     
    factor *= 10;
  }
   
  return count;
}


分析:

方法一就是从1开始遍历到N,将其中的每一个数中含有“1”的个数加起来,比较好想。

方法二比较有意思,核心思路是这样的:统计每一位上可能出现1的次数。

比如123:

个位出现1的数字:1,11,13,21,31,...,91,101,111,121

十位出现1的数字:10~19,110~119

百位出现1的数字:100~123

总结其中每位上1出现的规律即可得到方法二。其时间复杂度为O(Len),Len为数字长度

整数的二进制表示中 1 的个数
题目:整数的二进制表示中 1 的个数

要求:

输入一个整数,求该整数的二进制表达中有多少个 1。

例如输入 10,由于其二进制表示为 1010,有两个 1,因此输出 2。

分析:

解法一是普通处理方式,通过除二余二统计1的个数;

解法二与解法一类似,通过向右位移依次处理,每次与1按位与统计1的个数

解法三比较奇妙,每次将数字的最后一位处理成0,统计处理的次数,进而统计1的个数

代码实现(GCC编译通过):

#include "stdio.h"
#include "stdlib.h"
 
int count1(int x);
int count2(int x);
int count3(int x);
 
int main(void)
{
  int x;
  printf("输入一个数:\n");
  setbuf(stdin,NULL);
  scanf("%d",&x);
  printf("%d转二进制中1的个数是:",x);
  printf("\n解法一:%d",count1(x));
  printf("\n解法二:%d",count2(x));
  printf("\n解法三:%d",count3(x));
   
  printf("\n");
  return 0;
}
 
//除二、余二依次统计每位
int count1(int x)
{
  int c=0;
  while(x)
  {
    if(x%2==1)
      c++;
    x/=2;
  }
  return c;
}
 
//向右移位,与1按位与统计每位
int count2(int x)
{
  int c=0;
  while(x)
  {
    c+=x & 0x1;
    x>>=1;
  }
  return c;
}
 
//每次将最后一个1处理成0,统计处理次数
int count3(int x)
{
  int c=0;
  while(x)
  {
    x&=(x-1);
    c++;
  }
  return c;
}

您可能感兴趣的文章:

相关文章

  • C语言实现扫雷小游戏

    C语言实现扫雷小游戏

    这篇文章主要为大家详细介绍了C语言实现扫雷小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-11-11
  • c++如何实现归并两个有序链表

    c++如何实现归并两个有序链表

    这篇文章主要介绍了c++如何实现归并两个有序链表,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • DSP中浮点转定点运算--浮点与定点概述

    DSP中浮点转定点运算--浮点与定点概述

    本文主要介绍DSP中浮点与定点概述,很值得学习一下,需要的朋友可以参考一下。
    2016-06-06
  • C++ 基础函数的介绍及使用(Vector+deque+STL)

    C++ 基础函数的介绍及使用(Vector+deque+STL)

    这篇文章主要介绍了C++ 基础函数的介绍及使用(Vector+deque+STL),文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-06-06
  • C++11实现字符串分割的示例

    C++11实现字符串分割的示例

    本文主要介绍了C++11实现字符串分割的示例,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • C++中std::vector的6种初始化方式

    C++中std::vector的6种初始化方式

    这篇文章主要介绍了C++中std::vector的6种初始化方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • Qt+Quick实现播放音乐和视频的开发

    Qt+Quick实现播放音乐和视频的开发

    这篇文章主要为大家详细介绍了如何利用Qt+Quick实现播放音乐和视频的开发,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-03-03
  • C语言实现倒置字符串的两种方法分享

    C语言实现倒置字符串的两种方法分享

    这篇文章主要和大家详细介绍了利用C语言实现倒置字符串的两种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起动手尝试一下
    2022-08-08
  • C++线程安全的队列你了解嘛

    C++线程安全的队列你了解嘛

    这篇文章主要为大家详细介绍了C++线程安全的队列,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • C++使用curl库的完成流程

    C++使用curl库的完成流程

    curl 是一个利用URL语法在命令行方式下工作的文件传输工具,curl不但提供了一个可执行的工具库,还提供了供程序开发的libcurl库,该库使用c语言编写,支持跨平台,本文给大家介绍了C++使用curl库的完成流程,需要的朋友可以参考下
    2024-09-09

最新评论