c语言题目之统计二级制数中1的个数

2024-01-05 23:36

本文主要是介绍c语言题目之统计二级制数中1的个数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 题目
  • 一、方法1
  • 二、方法2
  • 三,方法3
  • 总结


题目

统计二进制数中1的个数
输入一行,输出一行
输入: 输入一个整数
输出: 输出存储在内存中二进制的1的个数

一、方法1

之前的文章中,小编写了有关于内存在二进制中的存储方法,正整数在二进制中存储在内存中存储的是二进制的原码,负整数在内存中存储的是二进制的补码。在这里我们随机输入一个整数,假如小编输入15,那么15在内存中存储如下图,然后我们让他按位与上一个1,在操作符中按位与语法就是两个1为1否则为0,在这里我们让15在内存中存储的二进制最低位与上1,然后二进制位右移一位让第二位与上1,因为整数在内存中存储4个字节也就是32个比特位,所以我们只需要向右移动32次就结束即可,下面上代码

在这里插入图片描述

int addcou(int i)
{int flag = 1;int count = 0;int x = 32;while (x != 0){if ((i & 1) == 1){count += 1;>   }i = i >> 1;   x--;   }return count;   
}
int main()   
{int i = 0;   scanf("%d",&i);   int count = addcou(i);   printf("%d",count);   return 0;   
}

在这里插入图片描述

二、方法2

在这里我们输入15,因为是二进制数,也就是说它的存储只有0和1,我们求它的余数要让它的范围为0和1,所以我们进来先让他取模2,在这里我们需要设置一个加数器,在这里如果取模等于1的话,计数器加1,然后再去除以2,这个也就是我们十进制转二进制数的方法,当我们最后除到最后的时候就等于0然后就没有继续换算下去,如下图,接下来上代码理解
在这里插入图片描述

int addcou(unsigned int i) //在这里传进来是有符号数,所以-1不够除,但是如果是无符号数,我们就会把他看成一个很大的整数这样就能求了
{int count = 0;while (i){if ((i % 2) == 1){count++;}i = i / 2;}return count;
}
int main()
{int i = 0;scanf("%d",&i);int count = addcou(i);printf("%d",count);return 0;
}

在这里插入图片描述

分析

在这里为什么传参接收用无符号整型接收呢?假如我们输入-1,而-1在内存中存储的就是它的反码,也就是32个1,但是我们如果我们直接用整型接收,因为系统默认int为有符号整型,我们这里接收-1,-1取模2不够所以得到0,然后在去除以2还是不够值所以得到-1,循环所以就是0个1,但是事实就是-1在内存中存储有32个1,因此我们用无符号整型接收,这样它就默认它二进制数也就是全是1为一个很大的整数,这样就可以统计出二进制中1的个数。

三,方法3

在这里我们接下来看到一个数假设我们输入为15,则二进制位1111,我们这里传入的是n然后让n*(n-1)

n = 15
n = n &(n-1);
1111 n
1110 n-1
1110 n
1101 n-1
1100 n
1011 n-1
1000 n
0111 n-1
0000 n
在这里我们可以发现每次按位与一次就消去一个1,这样我们设置一个计数器,按位与一次加一然后到最后按位与为0结束,接下来上代码理解:

int addcou(int i)
{int count = 0;while (i){i = i & (i - 1);count++;}return count;
}
int main()
{int i = 0;scanf("%d",&i);int count = addcou(i);printf("%d",count);return 0;
}

在这里插入图片描述


总结

以上就是今天要讲的内容,本文仅仅简单介绍了c语言题目之统计二级制数中1的个数的使用,各位读者有其它解法欢迎打在评论区。

这篇关于c语言题目之统计二级制数中1的个数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/574517

相关文章

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

IDEA与MyEclipse代码量统计方式

《IDEA与MyEclipse代码量统计方式》文章介绍在项目中不安装第三方工具统计代码行数的方法,分别说明MyEclipse通过正则搜索(排除空行和注释)及IDEA使用Statistic插件或调整搜索... 目录项目场景MyEclipse代码量统计IDEA代码量统计总结项目场景在项目中,有时候我们需要统计

Go语言使用Gin处理路由参数和查询参数

《Go语言使用Gin处理路由参数和查询参数》在WebAPI开发中,处理路由参数(PathParameter)和查询参数(QueryParameter)是非常常见的需求,下面我们就来看看Go语言... 目录一、路由参数 vs 查询参数二、Gin 获取路由参数和查询参数三、示例代码四、运行与测试1. 测试编程路

Go语言使用net/http构建一个RESTful API的示例代码

《Go语言使用net/http构建一个RESTfulAPI的示例代码》Go的标准库net/http提供了构建Web服务所需的强大功能,虽然众多第三方框架(如Gin、Echo)已经封装了很多功能,但... 目录引言一、什么是 RESTful API?二、实战目标:用户信息管理 API三、代码实现1. 用户数据

Go语言网络故障诊断与调试技巧

《Go语言网络故障诊断与调试技巧》在分布式系统和微服务架构的浪潮中,网络编程成为系统性能和可靠性的核心支柱,从高并发的API服务到实时通信应用,网络的稳定性直接影响用户体验,本文面向熟悉Go基本语法和... 目录1. 引言2. Go 语言网络编程的优势与特色2.1 简洁高效的标准库2.2 强大的并发模型2.

Go语言使用sync.Mutex实现资源加锁

《Go语言使用sync.Mutex实现资源加锁》数据共享是一把双刃剑,Go语言为我们提供了sync.Mutex,一种最基础也是最常用的加锁方式,用于保证在任意时刻只有一个goroutine能访问共享... 目录一、什么是 Mutex二、为什么需要加锁三、实战案例:并发安全的计数器1. 未加锁示例(存在竞态)

C语言自定义类型之联合和枚举解读

《C语言自定义类型之联合和枚举解读》联合体共享内存,大小由最大成员决定,遵循对齐规则;枚举类型列举可能值,提升可读性和类型安全性,两者在C语言中用于优化内存和程序效率... 目录一、联合体1.1 联合体类型的声明1.2 联合体的特点1.2.1 特点11.2.2 特点21.2.3 特点31.3 联合体的大小1