谁是单身狗?——C语言刷题


创造不易,可以点点赞吗~

如有错误,欢迎指出~



单身狗1

题述

在一个整型数组中,只有一个数字出现一次,其他数组都是成对出现的,请找出那个只出现一次的数字。
例如:

数组中有:1 2 3 4 5 1 2 3 4,只有5出现一次,其他数字都出现2次,找出5

分析

我们可以用按位异或操作符解决

其中根据 按位异或的特点(同为0,异为1)

  • n^0==n;
  • n^n==0;

如下代码中0分别与数组元素按位异或,如第一次0^1==1,1^1==0……直到最后0^5==5找到了单身狗。

代码

#include<stdio.h>
int main()
{int arr[9] = { 1,2,3,4,5,1,2,3,4 };int sz = sizeof(arr) / sizeof(arr[0]);int n = 0;for (int i = 0; i < sz; i++){n = n ^ arr[i];}printf("单身狗是%d", n);return 0;
}

结果

单身狗2

题述

一个数组中只有两个数字是出现一次,其他所有数字都出现了两次。

编写一个函数找出这两个只出现一次的数字。

例如:

有数组的元素是:1,2,3,4,5,1,2,3,4,6

只有5和6只出现1次,要找出5和6.

分析

分3步走

1.将所有数字异或

将数字1,2,3,4,5,1,2,3,4,6全部相互异或得到5和6的异或结果0011

5  0101       6   0110

1  0001       2   0010

4  0100       3   0011

2.确定二进制位1的不同处

其中5,1,4的倒数第二位都为0,而6,2,3的倒数第二位都为1

3.将5,1,4分为一组,6,2,3分为一组,最后将他们分别异或得到结果

代码

#include<stdio.h>
void find_num(int arr[], int n, int* pn1, int* pn2)
{//1.将所有数字异或int ret = 0;for (int i = 0; i < n; i++){ret ^= arr[i];}//最后得到的结果是5和6的异或int pos = 0;//2.确定ret二进制为1的位置for (int i = 0; i < 32; i++){if ((ret >> i) & 1 == 1){pos = i;break;}}//3.分组,pos为1的一组,pos为2的一组for (int i = 0; i < n; i++){if ((arr[i] >> pos & 1) == 1){*pn1 ^= arr[i];}else{*pn2 ^= arr[i];}}
}
int main()
{int arr[] = { 1,2,3,4,5,1,2,3,4,6 };int len = sizeof(arr) / sizeof(arr[0]);int n1 = 0;int n2 = 0;find_num(arr, len, &n1, &n2);printf("单身狗是%d和%d\n", n1, n2);return 0;
}

运行结果

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQL 中如何实现多表关联查询?

阅读本文之前请参阅----MySQL 数据库安装教程详解&#xff08;linux系统和windows系统&#xff09; 在SQL中&#xff0c;多表关联查询是通过使用JOIN操作来实现的&#xff0c;它允许你从两个或多个表中根据相关列的值来检索数据。以下是几种常见的JOIN类型&#xff1a; …

设计模式-结构型模式-适配器模式

0 引言 结构型模式&#xff08;Structural Pattern&#xff09;关注如何将现有类或对象组织在一起形成更加强大的结构。 1 适配器模式 适配器模式&#xff08;Adapter Pattern&#xff09;&#xff1a;将一个接口转换成客户希望的另一个接口&#xff0c;使接口不兼容的那些类…

【前端素材】推荐实用的后台管理系统ebazer电商平台模板(附带源码)

一、需求分析 后台管理系统网站是指用于管理和控制网站、应用程序或系统后台运行的管理工具。它通常是网站或应用程序的管理者、管理员或内容编辑人员使用的界面&#xff0c;具有一系列功能来管理用户、内容、数据和系统设置。以下是后台管理系统网站的功能和特点&#xff1a;…

FPS游戏漫谈优化包体传输

在游戏服务器的部署环境中&#xff0c;机房的网络带宽都是有限制的。如果通信传输的数据总量太大&#xff0c;会挤占带宽甚至达到带宽上限&#xff0c;影响正常消息发送。另外&#xff0c;如果包体太大&#xff0c;在弱网环境下的通信质量会变差&#xff0c;更容易发生丢包重传…

C#之WPF学习之路(5)

目录 内容控件&#xff08;2&#xff09; TextBlock文字块 TextBox文本框 TextBoxBase基类 TextBox控件 RichTextBox富文本框 ToolTip控件&#xff08;提示工具&#xff09; Popup弹出窗口 Image图像控件 属性成员 事件成员 内容控件&#xff08;2&#xff09; Tex…

【错误处理】

错误处理 deferrecover机制处理错误自定义错误 deferrecover机制处理错误 【1】展示错误&#xff1a; 发现&#xff1a;程序中出现错误/恐慌以后&#xff0c;程序被中断&#xff0c;无法继续执行。 【2】错误处理/捕获机制&#xff1a; go中追求代码优雅&#xff0c;引l入机…

Docker安装MS SQL Server并使用Navicat远程连接

MS SQL Server简介 Microsoft SQL Server&#xff08;简称SQL Server&#xff09;是由微软公司开发的关系数据库管理系统&#xff0c;它是一个功能强大、性能卓越的企业级数据库平台&#xff0c;用于存储和处理大型数据集、支持高效查询和分析等操作。SQL Server 支持广泛的应…

PMP项目管理考试要注意些什么?

PMP考试和PMP备考过程中应该注意哪些问题&#xff1f; PMP备考完成后就要迎接实战考试了&#xff0c;考试前千万不要有多余的想法&#xff0c;顺其自然就行了&#xff0c;我想大家各种紧张、各种忧虑的原因大抵是因为考试成本考&#xff0c;担心考不过&#xff0c;其实只要你在…

蓝桥杯《修剪灌木》

题目描述 爱丽丝要完成一项修剪灌木的工作。有 N 棵灌木整齐的从左到右排成一排。爱丽丝在每天傍晚会修剪一棵灌木&#xff0c;让灌木的高度变为 0 厘米。爱丽丝修剪灌木的顺序是从最左侧的灌木开始&#xff0c;每天向右修剪一棵灌木。当修剪了最右侧的灌木后&#xff0c;她会…

[word] word竖排文字时,如何让英文和数字也纵向显示 #笔记#经验分享

word竖排文字时&#xff0c;如何让英文和数字也纵向显示 用Word进行排版成为我们办公中的主要方式&#xff0c;偶尔我们也可能会让文字竖着排版&#xff0c;让文字竖着排版我们都知道怎么操作&#xff0c;但是如何让英文和数字也纵向显示呢&#xff1f;接下来这篇文章就告诉你…

2.23 Qt day4 事件机制+定时器事件+键盘事件+鼠标事件

思维导图&#xff1a; 做一个闹钟&#xff0c;在行编辑器里输入定闹钟的时间&#xff0c;时间到了就语音播报文本里的内容&#xff0c;播报五次 widget.h&#xff1a; #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include<QDebug>//输出类 #include<…

【MySQL】学习和总结联合查询

&#x1f308;个人主页: Aileen_0v0 &#x1f525;热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法 ​&#x1f4ab;个人格言:“没有罗马,那就自己创造罗马~” #mermaid-svg-OPj5g6evbkm5ol0U {font-family:"trebuchet ms",verdana,arial,sans-serif;font-siz…