C语言初阶必会的练习题(3)之位操作符(^ 、、>>等)的应用

ops/2024/11/14 6:31:29/

C语言初阶必会的练习题(3)

  • 放在最前面的
  • 1、不允许创建临时变量,交换两个整数的内容
    • 1.1、分析:见代码注释
        • (a)方法 1
        • (b)方法 2
    • 1.2、结果展示
        • 方法 1 的 结果:
        • 方法 2 的 结果:
  • 2、统计二进制中1的个数
    • 2.1、分析:见代码注释
        • (a)方法 1
        • (b)方法 2
            • 方法 2 的原理图
        • (c)方法 3
            • 方法 3 的原理图
    • 2.2、结果展示
        • 方法 1 的 结果:
        • 方法 2 的 结果:
        • 方法 3 的 结果:
  • 3、打印整数二进制的奇数位和偶数位
    • 3.1、分析:见代码注释
    • 3.2、结果展示
        • 展示 1
        • 展示 2
  • 4、求两个数 二进制中不同位的个数
    • 4.1、分析:见代码注释
    • 4.2、结果展示
  • END

放在最前面的

🎈🎈 我的CSDN主页:OTWOL的主页,欢迎!!!👋🏼👋🏼
🎉🎉我的C语言初阶合集:C语言初阶合集,希望能帮到你!!!😍 😍
👋🏼🎉🎊创作不易,欢迎大家留言、点赞加收藏!!! 🥳😁😍

1、不允许创建临时变量,交换两个整数的内容

1.1、分析:见代码注释

(a)方法 1
//(方法 1):可以使用加减法,然后实现两个数字的互换 #include<stdio.h>//方法1
int main()
{//定义两个整型变量 a、bint a = 0;int b = 0;//输入scanf("%d %d", &a, &b);//定义一个整型变量 sumint sum = 0;//将 a + b的值赋值给 sumsum = a + b;//进行加减法操作,实现两个数字 的交换a = sum - a;//即 a = a + b - a = bb = sum - a ;//即 b = a + b - b = a//输出printf("%d %d\n", a, b);return 0;
}
(b)方法 2

补充 ( ^ 按位异或操作符) 的使用:

对 按位异或操作符 ( ^ )还感到一头雾水的小伙伴们,快来点击下面的这篇超实用博客文章👇,一起揭开它的神秘面纱吧!🔍✨
C语言中操作符详解(上)


方法2的原理图:

  • 图片 1

  • 图片 2

  • 图片 3

  • 图片 4

//(方法2):可以使用位操作符(^ -- 按位异或) #include<stdio.h>int main()
{//定义三个整型变量 a、b、cint a = 0;int b = 0;int c = 0;//输入scanf("%d %d", &a, &b);//使用位操作符(^ -- 按位异或),实现两个数字 的交换c = a ^ b;b = c ^ b;a = c ^ a;//输出printf("%d %d\n", a, b);return 0;
}

1.2、结果展示

输入两个数字: - 5 和 10

方法 1 的 结果:

方法 2 的 结果:

在这里插入图片描述

2、统计二进制中1的个数

描述:

写一个函数返回参数二进制中 1 的个数。
比如: 15
二进制位:0000 1111
有4 个 1

2.1、分析:见代码注释

(a)方法 1
//统计二进制中1的个数
// 
//首先我们先把问题拆分成我们熟悉的问题
//(1)要得到二进制数的每一位
//(2)进行统计 二进制数字 1 的个数
// 
//(1)要得到二进制数的每一位
//类比 输出十进制的每一位是 
// (i)  % 10
// (ii) / 10
// 
//(2)进行统计 二进制数字 1 的个数
//在得到每一位的数字时候,判断是否为 1
//是 1 则 计数器加 1,反之,则不进入 if 语句 #include<stdio.h>//定义一个 NumberOf1 函数,返回类型是 int, 
//参数是 unsigned int(无符号整型) n
int NumberOf1(unsigned int n)
{//定义一个计数器int count = 0;// while 循环while (n != 0){//判断 n % 2 的结果是否等于 1if ((n % 2) == 1){//如果是,则 count + 1count++;}// 将 n / 2 赋值给 nn = n / 2;}//返回 countreturn count;
}int main()
{//定义int n = 0;//输入scanf("%d", &n);//调用函数,用于输出数字的每一位,并统计 1 的个数int ret = NumberOf1(n);//输出printf("%d", ret);return 0;
}
(b)方法 2

补充:
嘿小伙伴们!👋🏼 如果有人对C语言里 按位与(&)操作符📜 还感到一头雾水🤯,别急!😌 点击下面的链接🔗,让我们一起复习一下,
把这些让人头疼的概念搞定吧!💪💡

C语言中操作符详解(上)

方法 2 的原理图

#include<stdio.h>int NumberOf1(int n)
{//定义一个计数器int count = 0;//定义一个整型变量 iint i = 0;// for 循环 for (i = 0; i < 32; i++){// if 条件判断语句// 判断是条件是 (n >> i) -- n 右移 i 位// 与 1 进行相与(对应的二进制序列 有 0 则是 0,两个同时为 1 才为 1)// 的结果是否 等于 1if (((n >> i) & 1) == 1){//如果是,则 count+1count++;}}//返回 countreturn count;
}int main()
{//定义int n = 0;//输入scanf("%d", &n);//调用函数,并统计 1 的个数int ret = NumberOf1(n);//输出printf("%d", ret);return 0;
}
(c)方法 3
方法 3 的原理图

int NumberOf1(int n)
{//定义一个计数器int count = 0;// while 循环while (n != 0){//进入循环即 n != 0,则 count + 1count++;// 将 n 和 (n - 1)  进行 相与(对应的二进制序列 有0 则是 0,两个同时为 1 才为1)// 并将结果 赋值给 nn = n & (n - 1);}//返回 countreturn count;
}int main()
{//定义int n = 0;//输入scanf("%d", &n);//调用函数,并统计 1 的个数int ret = NumberOf1(n);//输出printf("%d", ret);return 0;
}

2.2、结果展示

方法 1 的 结果:

方法 2 的 结果:

方法 3 的 结果:

3、打印整数二进制的奇数位和偶数位

描述:

获取一个整数二进制序列中所有的偶数位和奇数位,
分别打印出二进制序列

3.1、分析:见代码注释

  • 思路展示:

void Print(int n)
{//定义一个整型变量 iint i = 0;//打印提示信息printf("奇数位:");// for 循环 for (i = 30; i >= 0; i -= 2){printf("%d ", (n >> i) & 1);}//打印提示信息printf("\n偶数位:");// for 循环 for (i = 31; i >= 1; i -= 2){printf("%d ", (n >> i) & 1);}
}int main()
{//定义int n = 0;//输入scanf("%d", &n);//调用函数,用于打印整数二进制的奇数位和偶数位Print(n);return 0;
}

3.2、结果展示

展示 1
  • 输入数字 1

  • 数字1 在32位机器上的二进制序列

  • VS输出结果图片展示

展示 2
  • 输入数字 10

  • 数字10 在32位机器上的二进制序列

  • VS输出结果图片展示


4、求两个数 二进制中不同位的个数

描述:

编程实现:
两个int(32位)整数m和n的二进制表达中,有多少个位(bit)不同?
输入例子: 1999 2299
输出例子:7

4.1、分析:见代码注释

#define _CRT_SECURE_NO_WARNINGS 1#include<stdio.h>int main()
{//定义两个整型变量 a、bint a = 0;int b = 0;//输入scanf("%d %d", &a, &b);//定义一个整型变量 iint i = 0;//定义一个整型变量 count,用作计数器int count = 0;// for 循环for (i = 0; i < 32; i++){// if 条件语句//  判断条件是 a 和 b 的每一位(右移 i 位操作)分别与 1 进行 //  按位与(对应的二进制序列,数字同时为 1才为 1,有 0 则为 0)//   即得到 a 和 b 的二进制序列的每一位进行 一 一 比较if (((a >> i) & 1) != ((b >> i) & 1)){//计数器 count 加 1count++;}}//输出printf("%d\n", count);return 0;
}

4.2、结果展示

输入例子: 1999 2299
输出例子: 7

END

每天都在学习的路上!
On The Way Of Learning

“亲爱的读者们,文章到这里就结束啦😃。在阅读过程中有没有遇到什么疑问等等❓欢迎在评论区留言告诉我哦,期待与你的互动交流🤗!”


http://www.ppmy.cn/ops/133057.html

相关文章

Kafka高频面试题详解(consumer端)

1、消费者组和分区数之间的关系是怎样的&#xff1f; 消费者组内每个消费者负责消费不同分区的数据&#xff0c;一个分区只能由一个组内消费者消费 消费者组之间互不影响&#xff0c;所有的消费者都属于某个消费者组&#xff0c;即消费者组是逻辑上的一个订阅者 2、kafka如何知…

el-table 纵向垂直表头处理

项目中表格展示会遇到需要纵向垂直表头情况&#xff0c;下面&#xff0c;我们基于el-table组件来实现这种表格。 以下是这次需要用到的数据表格&#xff0c;已知左侧违章名称是固定的&#xff0c;而月份是不固定的&#xff0c;在后端返回数据格式已确定的情况下&#xff0c;需…

在心理学研究中实施移动眼动追踪:实用指南

摘要 眼动追踪提供了直接的、时间和空间敏感的眼球注视测量。它能够捕捉从婴儿期到成年期的视觉注意模式。然而&#xff0c;常用的基于屏幕的眼动追踪(SET)方法在描绘个体如何在“现实生活”中与环境互动时的信息处理上存在局限性。移动眼动追踪(MET)记录参与者在主动行为背景…

kafka的安装与使用

目录 一、 简介 1.1、概念 1.2、核心成员 1.3、特点 二、安装 2.1、zookeeper 2.2、上传解压重命名 2.3、修改配置文件 2.4、启动 2.5、一个启停脚本 三、使用 3.1、主题命令行操作 3.1.1查看操作主题命令参数 3.1.2创建 first topic 3.1.3查看当前服务器中的所有…

【MySQL】MySQL基础知识复习(下)

前言 上一篇博客介绍了MySQL的库操作&#xff0c;表操作以及CRUD。 【MySQL】MySQL基础知识复习&#xff08;上&#xff09;-CSDN博客 本篇将进一步介绍CRUD操作&#xff0c;尤其是查找操作 目录 一.数据库约束 1.约束类型 1.1NULL约束 1.2UNIQUE&#xff1a;唯一约束 …

lua入门教程:math

在Lua中&#xff0c;math库是一个非常重要的内置库&#xff0c;它提供了许多用于数学计算的函数。这些函数可以处理各种数学运算&#xff0c;包括基本的算术运算、三角函数、对数函数、随机数生成等。结合你之前提到的Lua中的数字遵循IEEE 754双精度浮点标准&#xff0c;我们可…

【Visual Studio系列教程】什么是 Visual Studio?

欢迎阅读本文&#xff01;这意味着你可能已经准备好开始学习如何使用 Visual Studio 进行开发。既然如此&#xff0c;我们就不多做废话&#xff0c;直接进入本系列的第1篇文章&#xff1a;《什么是 Visual Studio&#xff1f;》。 Visual Studio 是一款功能强大的开发人员工具…

Linux——简单认识vim、gcc以及make/Makefile

前言&#xff1a;大佬写博客给别人看&#xff0c;菜鸟写博客给自己看&#xff0c;我是菜鸟。 1、vim操作&#xff1a; 默认打开vim时&#xff0c;vim处于命令模式。(在其他模式中&#xff0c;Esc就能够返回命令模式) 常用的命令有&#xff1a; n gg&#xff1a;跳转到n行&…