返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言每日一练------Day(6)
  • 131
分享到

C语言每日一练------Day(6)

c语言C语言每日一题 2023-08-30 16:08:22 131人浏览 安东尼
摘要

本专栏为C语言练习专栏,适合刚刚学完c语言的初学者。本专栏每天会不定时更新,通过每天练习,进一步对c语言的重难点知识进行更深入的学习。 今日练习题关键字:整数转换 异或 💓博主csdn个人主页:小小unic

本专栏为C语言练习专栏,适合刚刚学完c语言的初学者。本专栏每天会不定时更新,通过每天练习,进一步对c语言的重难点知识进行更深入的学习

今日练习题关键字:整数转换 异或

在这里插入图片描述

💓博主csdn个人主页:小小unicorn
⏩专栏分类:C语言天天练
🚚代码仓库:小小unicorn的代码仓库🚚
🌹🌹🌹关注我带你学习编程知识

题目一:

题目描述:

整数转换。编写一个函数,确定需要改变几个位才能将整数A转成整数B。

在这里插入图片描述

解题思路:

题目来源:整数转换
首先我们要明白异或运算符的原理,^ 这个就是异或运算符,两整数二进制位进行逐位比较,相同为0,相异为1,比如我们的数字1,二进制表示为 0001,数字2,二进制表示为 0010,对1和2进行异或,结果为 0011。这就是相同为0,相异为1的规则。

现在我们来看题目,题目要求的是两数转换需要变动多少位(二进制位),换句话说,题目问的是两数二进制之间有多少处不同

我们先把两数异或,把值存在变量 c 中,然后再用到我们的按位与运算符,即 &,和按位异或不同,按位与是两整数二进制位逐位进行比较,遇0为0,否则为1,这里我们利用数字1,因为它的二进制中只有1个1,且在最右边,我们可以把它们进行比较。

因为1只有最右边为1,所以如果想32位都能比到的话,就需要我们的右移操作符了,每比较一次,我们的变量 c 就向右移动一位(左端补符号位),此时只需要在外面套上for循环,循环次数为32次,这样我们就能把 c 中的每一位与数字1进行 按位与 比较了。

只要我们在 c 的二进制位中找到一个1,计数器count就++,最后程序返回count的值就行了。

代码实现:

int convertInteger(int A, int B){    //位运算,先异或(相同为0,相异为1)    //再利用0的二进制进行与运算(遇1为1)    int c = A ^ B;//两数异或后的值    int i = 0;//循环控制器    int count = 0;//计数器    for(i = 0 ;i < 32 ;i++)    {        if(c & 1 == 1)//利用与1的 按位与 运算,发现一个1,计数器就++        {            count++;        }        c >>= 1;// c 变量的二进制位往右移动一位     }    return count;//返回计数器的值}

结果情况:

在这里插入图片描述
符合题目要求,问题得到解决。

题目二:

题目描述:

题目来源:数字在升序数组中出现的次数
给定一个长度为 n 的非降序数组和一个非负数整数 k ,要求统计 k 在数组中出现的次数
数据范围:0≤n≤1000,0≤k≤100,数组中每个元素的值满足
要求:空间复杂度 O(1),时间复杂度 O(logn)

在这里插入图片描述

解题思路:

因为是有序的,所以用二分查找更快。找到比k小的第一个数作为左边界,找到比k大的第一个数作为右边界,右-左即k的个数。

按普通找某个数的位置来找,只是把int 改为double, 找k-0.5和k+0.5

代码实现:

int position(int* data, int n, double k) {    int left = 0, right = n - 1, mid = 0;    while (left <= right)     {        mid = (left + right) / 2;        if (data[mid] < k)            left = mid + 1;        else if (data[mid] > k)            right = mid - 1;        else            return mid;    }    return left;}int GetNumberOfK(int* data, int dataLen, int k ) {    return position(data, dataLen, k + 0.5) - position(data, dataLen, k - 0.5);}}

结果情况:

在这里插入图片描述
符合题目要求,问题得到解决。

总结

文章到这里就要告一段落了,有更好的想法或问题,欢迎评论区留言。
希望今天的练习能对您有所收获,咱们下期见!

来源地址:https://blog.csdn.net/weixin_72066135/article/details/132571106

--结束END--

本文标题: C语言每日一练------Day(6)

本文链接: https://lsjlt.com/news/383301.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C语言每日一练------Day(6)
    本专栏为c语言练习专栏,适合刚刚学完c语言的初学者。本专栏每天会不定时更新,通过每天练习,进一步对c语言的重难点知识进行更深入的学习。 今日练习题关键字:整数转换 异或 💓博主csdn个人主页:小小unic...
    99+
    2023-08-30
    c语言 C语言每日一题
  • C语言每日一练------Day(5)
    本专栏为c语言练习专栏,适合刚刚学完c语言的初学者。本专栏每天会不定时更新,通过每天练习,进一步对c语言的重难点知识进行更深入的学习。 今日练习题关键字:错误的集合 密码检查 💓博主csdn个人主页:小小u...
    99+
    2023-08-30
    c语言 C语言每日一题 数据结构
  • c语言每日一练(4)
    五道选择题 有以下代码,程序的输出结果是( ) #include int main(){int a = 0, b = 0;for (a = 1, b = 1; a = 20) break;//1if (b % 3 == 1)//2{b = ...
    99+
    2023-08-31
    c语言 算法 c++
  • python每日一练(6)
       🌈write in front🌈 🧸大家好,我是Aileen🧸.希望你看完之后,能对你有所帮助,不足请指正!共同学习交流. 🆔本文由Aileen_0v...
    99+
    2023-10-18
    前端 学习 算法 python 笔记 开发语言
  • C语言:选择+编程(每日一练)
    目录 选择题: 题一: 题二: 题三: 题四: 题五: 编程题: 题一:自除数 思路一: 题二:除自身以外数组的乘积 思路二: 本人实力有限可能对一些地方解释和理解的不够清晰,可以自己尝试读代码,或者评论区指出错误,望海涵! 感谢大佬们的...
    99+
    2023-08-31
    c语言 算法 开发语言 c++ 学习方法 笔记 迁移学习
  • 英语每日听写练习 Day 3
    Talk about holiday   My favorite part was playing volleyball on the beach, if I could, I would be at the beach everyday....
    99+
    2023-01-31
    英语 Day
  • C语言:选择+编程(每日一练Day14)
    目录 选择题: 题一: 题二: 题三: 题四: 题五: 编程题: 题一:珠玑妙算 思路一: 题二:两数之和 思路一: 本人实力有限可能对一些地方解释和理解的不够清晰,可以自己尝试读代码,或者评论区指出错误,望海涵! 感谢大佬们的一键三连!...
    99+
    2023-09-22
    c语言 算法 开发语言 笔记 深度学习 学习 c++
  • C语言每日练习之二叉堆
    目录一、堆的概念1、概述2、定义3、性质4、作用二、堆的存储结构1、根结点编号2、孩子结点编号3、父结点编号4、数据域5、堆的数据结构三、堆的常用接口1、元素比较2、交换元素3、空判...
    99+
    2024-04-02
  • C语言每日练习之选择排序
    目录分析代码实现总结分析 选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理是:第一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位...
    99+
    2024-04-02
  • C语言每日练习之进制转换
    目录分析代码实现网上参考总结分析 我一开始的想法是通过输入整数形式八进制来转换成十进制输出,后来发现用字符数组输入更方便。我这里就讲讲我用整型数据输入的转换思路: 我们都知道二进制...
    99+
    2024-04-02
  • C语言每日练习之冒泡排序
    目录分析代码实现运行结果总结分析 冒泡排序(Bubble Sort),是一种计算机科学领域的较简单的排序算法。 冒泡排序(这里只讨论从小到大排序)可以通过二种方式实现,分别是将最小...
    99+
    2024-04-02
  • C语言每日练习之字符串反转
    目录分析代码实现网上参考总结分析 在第18天:利用递归函数调用方式,将所输入的字符以相反顺序打印出来中,已经用过递归实现字符顺序输入,逆序输出,今天的题目是字符串反转,将以字符数组的...
    99+
    2024-04-02
  • Java日常练习题,每天进步一点点(6)
    目录1、以下二维数组声明合法的是( )2、3、使用mvc模式设计的web应用程序具有以下优点,除了?4、访问权限控制从最大权限到最小权限依次为:public、 包访问权限、prote...
    99+
    2024-04-02
  • python每日一练(4)
      🌈write in front🌈 🧸大家好,我是Aileen🧸.希望你看完之后,能对你有所帮助,不足请指正!共同学习交流. 🆔本文由Aileen_0v0...
    99+
    2023-10-20
    python 开发语言 学习 算法 抽象代数 github windows
  • python每日一练(7)
      🌈write in front🌈 🧸大家好,我是Aileen🧸.希望你看完之后,能对你有所帮助,不足请指正!共同学习交流. 🆔本文由Aileen_0v0...
    99+
    2023-10-20
    python 算法 学习 开发语言 服务器 青少年编程
  • python每日一练(5)
       🌈write in front🌈 🧸大家好,我是Aileen🧸.希望你看完之后,能对你有所帮助,不足请指正!共同学习交流. 🆔本文由Aileen_0v...
    99+
    2023-10-18
    前端 开发语言 python 学习 算法 服务器 数据结构
  • python每日一练(9)
       🌈write in front🌈 🧸大家好,我是Aileen🧸.希望你看完之后,能对你有所帮助,不足请指正!共同学习交流. 🆔本文由Aileen_0v...
    99+
    2023-10-26
    python 开发语言 笔记 经验分享 算法
  • C语言每日练习之乒乓球比赛问题
    目录题目描述分析代码实现后期完善网上参考解法一:解法二:总结题目描述 两个乒乓球队进行比赛,各出三人。甲队为a,b,c三人,乙队为x,y,z三人。已抽签决定比赛名单。有人向队员打听比...
    99+
    2024-04-02
  • C语言每日练习之动态显示系统时间
    目录分析代码实现1.简易版2.自定义格式版3.格式化输出版4.精细版(毫秒+微秒)网上参考总结分析 C语言的时间库函数基本都在time.h里,该头文件主要包含三种形式的时间量,一种是...
    99+
    2024-04-02
  • C语言每日练习之求两个矩阵的乘积详解
    目录分析代码实现总结分析 在数学中,矩阵(Matrix)是一个按照长方阵列排列的复数或实数集合,矩阵是高等代数学中的常见工具,也常见于统计分析等应用数学学科中。 矩阵的乘法有以下注...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作