C语言与操作符相关的经典例题

目录

一道变态的面试题:不能创建临时变量(第三个变量),实现两个数的交换。

编写代码实现:求一个整数存储在内存中的二进制中1的个数。  

 二进制位置0或者置1


如果以下的知识点不是很清楚的可以去看这篇文章:操作符详解(上)-CSDN博客

一道变态的面试题:不能创建临时变量(第三个变量),实现两个数的交换。

这个题如果没有那个限制条件,我们一般都是创建第三个变量来处理。

法一:

//创建临时变量
#include <stdio.h>
int main()
{
	int a = 0;
	int b = 0;
	printf("请输入交换前的变量a与b:");
	scanf("%d%d", &a, &b);
	int c = 0;
	c = a;
	a = b;
	b = c;
	printf("交换后a=%d,b=%d\n", a, b);
	return 0;
}

第二种方法可能也是比较容易想到的,通过计算和来减去对应的。

法二:


//加减法
#include <stdio.h>
int main()
{
	int a = 0;
	int b = 0;
	printf("请输入交换前的变量a与b:");
	scanf("%d%d", &a, &b);
	a = a + b;
	b = a - b;//a+b-b
	a = a - b;//a+b-a
	printf("交换后a=%d,b=%d\n", a, b);
	return 0;
}

这个法二其实严格来说,是有错误的。当a和b的值接近一个整形能存储的最大值是,它们两的和就会超出这个整形的最大值,从而导致溢出的问题。 

第三种方法应该只有那些大佬才能够想到。 

 法三:

#include <stdio.h>
int main()
{
	int a = 0;
	int b = 0;
	printf("请输入交换前的变量a与b:");
	scanf("%d%d", &a, &b);
	a = a ^ b;
	b = a ^ b;//a^b^b=a
	a = a ^ b;//a^b^a=b
	printf("交换后a=%d,b=%d\n", a, b);
	return 0;
}

这个方法涉及了一个知识点:0^a=a,a^a=0。

这个也用画图来解释一下吧: 

编写代码实现:求一个整数存储在内存中的二进制中1的个数。  

如果拿到这个题目的时候没思路的话,就可以先想一想十进制,求一个十进制数中1的个数,那么这个也就比较简单了,我们可以先%10,看看最后一位是否等于1,再/10赋给这个数更新一下,再%10拿到倒数第二位看看是否等于1,就这样一直%10,/10,知道最后这个/10的商为0,就可以停止了。同理,这个二进制我们也可以通过%2,/2的方法来计算。

#include <stdio.h>
int main()
{
	int n = 0;
	scanf("%d", &n);
	int count = 0;
	while (n)
	{
		if (n % 2 == 1)
		{
			count++;
		}
		n /= 2;
	}
	printf("%d\n", count);
	return 0;
}

但是很遗憾的是这个代码只能求正整数,而对于负整数就不行了。

例如:当我们输入-1时,输出的却是0。我们知道-1的补码全是1,正确输出的话应该要是32。

代码演示:

其实这个问题还是比较好解决的,既然负数不行,那我们就把它变成无符号数,而-1的补码是32个1,那么对应的无符号数就是一个非常大的数字了。

#include <stdio.h>
int main()
{
	unsigned int n = 0;
	scanf("%d", &n);
	int count = 0;
	while (n)
	{
		if (n % 2 == 1)
		{
			count++;
		}
		n /= 2;
	}
	printf("%d\n", count);
	return 0;
}

但是如果题目要求我们用的是有符号整数,那么我们应该怎么办呢? 其实这里就可以用到那个按位与(&)操作符。这里我们就按照那个思路来想一想,当给出了一个二进制数字,我们按位与(&)上一个1,那么我们就只要看第32个比特位了(因为两个数按位与(&)的规则是对应的二进制位同为1,才是1,否则为0。而1的二进制补码,只有第32个比特位才是1,其余的都是0,那么无论什么数按位与(&)1,最终的结果是前面的第31个都是0了,只有第32个比特位还不确定。),如果那个数第32个比特位为1,那么最终的结果就是1,如果那个数第32个比特位是0,那么最终的结果就是0了。这是第32位的计算结果,如果要想知道前面的结果,就只能通过移位符来来把前面的比特位移至最后一位,再来比较。这里可能有小伙伴会有疑问,为什么不移1呢?把1一位移位的移去前面来比较。其实这个移1,也不是不可以但是比起移那个数,还是要难一些。我们移1之后就表示判断结果等于1了,而是等不等于0,如果等于0,那么就没有1,如果不等于0,那么就有1。原因我就用图来表述了:

以上就是全部的思路,接下来就用代码演示:

移输入数的位

#include <stdio.h>
int main()
{
	int n = 0;
	scanf("%d", &n);
	int count = 0;
	int i = 0;
	for (i = 1; i <= 32; i++)
	{
		if (n & 1 == 1)
		{
			count++;
		}
		n >>= 1;//注意这里千万不能是移i位,因为i的数字是不断增加的,而不是定值。
	}
	printf("%d\n", count);
	return 0;
}
#include <stdio.h>
int main()
{
	int n = 0;
	scanf("%d", &n);
	int count = 0;
	int i = 0;
	for (i = 0; i < 32; i++)
	{
		if ((n >> i) & 1 == 1)
		{
			count++;
		}
	}
	printf("%d\n", count);
	return 0;
}

 上面这两种写法都是可以的。

移 1 的位 

#include <stdio.h>
int main()
{
	int n = 0;
	scanf("%d", &n);
	int count = 0;
	int i = 0;
	for (i = 0; i < 32; i++)
	{
		if ((n & (1 << i)) != 0)
		{
			count++;
		}
	}
	printf("%d\n", count);
	return 0;
}

上面这个题目其实还能优化(属于大佬能想到的)

我就先把代码演示一下:

#include <stdio.h>
int main()
{
	int n = 0;
	scanf("%d", &n);
	int count = 0;
	while (n)
	{
		n = n & (n - 1);
		count++;
	}
	printf("%d\n", count);
	return 0;
}

这个代码最难理解的就是那个 n = n & (n-1)。这个表达式可以把从右往左把最左边的1给去掉。

画图演示: 

这个代码其实算法的体现是比较明显了 ,一般不容易想到。

 二进制位置0或者置1

 编写代码将n的二进制序列的第5位(从右往左的第5位)(假设第5位是0)修改为1,然后再改回0。

这个题目应该是相较前面的难度要少一点。其实我们只要在第5位异或(^)一个1,就可以了。利用异或的规则:相异为1。至于这个第5位的1是怎么来实现呢?我们只需要讲1向移4位就够了。第二部,就在第5位按位异或(^)上一个1,就可以了。因为我们前面改了第5位的数变成了1,异或相同为0。

代码实现:

#include <stdio.h>
int main()
{
	int n = 0;
	scanf("%d", &n);
	n ^= (1 << 4);
	printf("%d\n", n);
	n ^= (1 << 4);
	printf("%d\n", n);
	return 0;
}

代码演示: 

我们上面就举了个最简单的例子0,任何一位都没有1,第5位改了之后就变成了2的4次方,等于16,第二次我们又改回来了,变成了0。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/353351.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

代码随想录算法训练营第十五天| 102. 二叉树的层序遍历、226.翻转二叉树、101. 对称二叉树

文章目录 1.二叉树的层序遍历2.翻转二叉树3.对称二叉树 1.二叉树的层序遍历 给你二叉树的根节点 root &#xff0c;返回其节点值的 层序遍历 。 &#xff08;即逐层地&#xff0c;从左到右访问所有节点&#xff09;。 示例 1&#xff1a; 输入&#xff1a;root [3,9,20,null…

3. SQL 语言

重点&#xff1a; MySQL 的 三种安装方式&#xff1a;包安装&#xff0c;二进制安装&#xff0c;源码编译安装。 MySQL 的 基本使用 MySQL 多实例 DDLcreate alter drop DML insert update delete DQL select 3&#xff09;SQL 语言 3.1&#xff09;关系型数据库的常见…

[晓理紫]每日论文分享(有中文摘要,源码或项目地址)--强化学习、模仿学习、机器人、开放词汇

专属领域论文订阅 关注{晓理紫|小李子}&#xff0c;每日更新论文&#xff0c;如感兴趣&#xff0c;请转发给有需要的同学&#xff0c;谢谢支持 如果你感觉对你有所帮助&#xff0c;请关注我&#xff0c;每日准时为你推送最新论文。 分类: 大语言模型LLM视觉模型VLM扩散模型视觉…

JVM工作原理与实战(二十九):监控内存泄漏的工具

专栏导航 JVM工作原理与实战 RabbitMQ入门指南 从零开始了解大数据 目录 专栏导航 前言 一、解决内存溢出的步骤 二、发现问题 1.Top命令 2.VisualVM 3.Arthas 4.Prometheus Grafana 总结 前言 JVM作为Java程序的运行环境&#xff0c;其负责解释和执行字节码&#x…

PyInstaller 将 Python 程序生成可直接运行的程序

图标转换地址&#xff1a;https://convert.app/#google_vignette 官方文档&#xff1a;https://readthedocs.org/projects/pyinstaller/downloads/pdf/stable/#page20 安装pyinstaller pip install pyinstaller执行打包 pyinstaller -i ./resource/w.icns -w -F whv.py --a…

VsCode CMake调试QT QString等变量不显示具体值,调试中查看qt源码 (可视化调试配置Natvis)

遇到的问题 当我们在VsCode使用CMake来调试QT程序时&#xff0c;可能会出现变量是十六进制的地址&#xff0c;而看不到具体的值。例如&#xff1a; 如何解决 这时候需要手动设置一下natvis &#xff08;资源以上传&#xff0c;可以直接下载&#xff09; 在.vscode文件下找到…

Ribbon 体系架构解析

前面已经介绍了服务治理相关组件&#xff0c;接下来趁热打铁&#xff0c;快速通关Ribbon&#xff01;前面我们了解了负载均衡的含义&#xff0c;以及客户端和服务端负载均衡模型&#xff0c;接下来我们就来看下SpringCloud 下的客户端负载均衡组件Ribbon 的特点以及工作模型。 …

uniapp微信小程序-请求二次封装(直接可用)

一、请求封装优点 代码重用性&#xff1a;通过封装请求&#xff0c;你可以在整个项目中重用相同的请求逻辑。这样一来&#xff0c;如果 API 发生变化或者需要进行优化&#xff0c;你只需在一个地方修改代码&#xff0c;而不是在每个使用这个请求的地方都进行修改。 可维护性&a…

P8651 [蓝桥杯 2017 省 B] 日期问题

#include <iostream> #include <string> using namespace std;int first; int second; int third; int day[13]{0,31,0,31,30,31,30,31,31,30,31,30,31};//每月日期bool select (int i,int j,int k){if ((i%100 first) && (j second) && (k thi…

Spring Cloud + Vue前后端分离-第13章 网站开发

源代码在GitHub - 629y/course: Spring Cloud Vue前后端分离-在线课程 Spring Cloud Vue前后端分离-第13章 网站开发 13-1 网站模块的搭建 新建web模板 1.网站开发&#xff0c;增加web模块&#xff0c;使用命令&#xff1a;vue create web vue版本4.2.3 大家拿到一个v…

第七篇【传奇开心果短博文系列】Python的OpenCV库技术点案例示例:图像拼接和融合

传奇开心果短博文系列 系列短博文目录Python的OpenCV库技术点案例示例短博文系列 短博文目录一、前言二、OpenCV图像拼接融合介绍三、全景图像拼接示例代码和扩展四、图像融合示例代码和扩展五、归纳总结 系列短博文目录 Python的OpenCV库技术点案例示例短博文系列 短博文目录…

el-table 设置内容超出宽度后省略,并添加tooltip

el-table 设置内容超出宽度后省略&#xff0c;并添加tooltip 只需要在el-table-item 标签中添加属性 :show-overflow-tooltip"true" 例子 <template><div style"width:100%; display: flex; justify-content: center;"><el-table :data&…

零基础学习数学建模——(五)美赛写作指导

本篇博客将详细讲解美赛论文写作。 文章目录 标题摘要目录引言问题背景问题重述前人研究我们的工作 模型假设及符号说明正文问题分析模型建立模型求解结果分析模型检验 模型优缺点及展望模型优缺点模型展望 参考文献及附录参考文献附录 2024年美赛论文新要求 标题 标题要简洁…

探索 SOAP:揭开 Web 服务的神秘面纱(上)

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

vscode配置扩展

1、微软提供的C/C扩展开发包 2、C/C智能提示 3、提供as汇编的语法高亮 4、提供文件夹和文件的显示主题 5、提供链接脚本的语法高亮 6、十六进制编辑器 7、MakeFile工具

Bug: git stash恢复误drop的提交

Bug: git stash恢复误drop的提交 前几天在写ut时突然需要通过本地代码临时出一个包&#xff0c;但是本地ut又不想直接作为一个commit提交&#xff0c;所以为了省事就将ut的代码暂时stash起来。出完包后想apply stash&#xff0c;但是手误操作点成了drop stash&#xff0c;丢失了…

Adobe ColdFusion 反序列化漏洞复现(CVE-2023-38203)

0x01 产品简介 Adobe ColdFusion是美国奥多比(Adobe)公司的一套快速应用程序开发平台。该平台包括集成开发环境和脚本语言。 0x02 漏洞概述 Adobe ColdFusion存在代码问题漏洞,该漏洞源于受到不受信任数据反序列化漏洞的影响,攻击者通过漏洞可以代码执行,可导致服务器失…

五个工业安全物联网解决方案

新一代物联网工具和应用正在帮助改变工业安全现状。传感器、可穿戴设备和位置标签提供实时数据&#xff0c;可以防止发生事故&#xff0c;并在出现故障时极大地缩短响应时间。 工业工作场所需要更加安全。根据国际劳工组织的数据&#xff0c;全球每年有近4亿工人因工受伤。近30…

matplotlib 波士顿房价数据及可视化 Tensorflow 2.4.0

matplotlib 波士顿房价数据及可视化 Tensorflow 2.4.0 目录 matplotlib 波士顿房价数据及可视化 Tensorflow 2.4.0 1. 认识 1.1 kears 1.2 kears常用数据集 2. 波士顿房价数据及可视化 2.1 下载波士顿房价数据集 2.2 展示一个属性对房价的影响 2.3 将是三个属性全部展…

【JavaSE篇】——数组的定义与使用

目录 本章的目标&#xff1a; &#x1f388;数组的基本概念 &#x1f36d;创建数组 &#x1f36d;数组的初始化 &#x1f36d;数组的使用 &#x1f449;数组中元素访问 &#x1f449;遍历数组 &#x1f388;数组是引用类型 &#x1f36d;初始JVM的内存分布 &#x1f…