【C语言刷题】找单身狗、模拟实现atoi
目录
一、找单身狗
1.暴力循环法
2.分组异或法
二、模拟实现atoi
1.atoi函数的功能
2.模拟实现atoi
一、找单身狗
题目描述:给定一个数组中只有两个数字是出现一次,其他所有数字都出现了两次。
编写一个函数找出这两个只出现一次的数字。
比如:[1,1,2,2,3,3,4,4,5,6]
单身狗是:5和6
1.暴力循环法
对于这道题,我们最容易想到的方法就是暴力循环遍历了。
我们设置两个下标或者两个指针,两层for循环来进行遍历求解。
但是缺陷是时间复杂度过大。当数据量很大的时候,效率很低
这种方法的代码实现也比较简单,这里也就不在赘述了
2.分组异或法
我们其实在前面的文章种已经讲解过一个找单身狗的问题了,只不过那个问题是一个数组中只有一个单身狗。我们可以根据异或操作符的特性,直接将整个数组进行异或就可以求解问题。
但是这道题目,我们发现有两个单身狗。因此我们不能单纯的将整体数组进行异或从而进行求解。
但是我们可以采用类似的思路。巧妙的使用异或操作符
我们是这样思考的,我们有没有什么办法能将两个单身狗给分离出去呢?也就是说将一个数组给分割成两个数组
每一个数组都需要满足这两个条件,两个单身狗需要在两个数组中,不能再、在一个数组中,其次我们还需要满足相同的两个数在同一组中
分成了两组以后,那么问题就简单了,两组分别异或,就得到了两个单身狗
那么如何将一个数组分割成满足这些条件的两个数组呢?我们要根据什么进行分组呢?
其实我们仍然可以根据异或操作符进行分组
我们对整个数组进行使用异或操作符,那么我们就可以得到两个单身狗异或的结果。这个结果的二进制序列中有1的位就是这两个单身狗的区别。根据这个区别,我们就可以将整个数组中,对应的这个位为1的分为一组,对应的这个位为0的分为一组。这样我们就完成了分组
比如说:[1,1,2,2,3,3,4,4,5,6]这个数组中
第一步:将整体异或得到101^110=011
第二步:我们发现011中有两个位不一样,我们随便选定一个即可,我们选定第一位
第三步分组:将上面的数组全部写成二进制的形式
[001,001,010,010,011,011,100,100,101,110]
根据第一位的不同分组结果如下:
第一组:[001,001,011,011,101],即[1,1,3,3,5]
第二组:[010,010,100,100,110],即[2,2,4,4,6]
第四步:分别异或
第一组异或为5,第二组异或为6
最终代码如下:
#include<stdio.h>
void find_signal_dog(int* arr, int sz, int* p)
{int i = 0;int ret = 0;for (i = 0; i < sz; i++){ret ^= arr[i];}int pos = 0;for (i = 0; i < 32; i++){if (((ret >> i) & 1 )== 1){pos = i;break;}}for (i = 0; i < sz; i++){if (((arr[i] >> pos) & 1 )== 1){p[0] ^= arr[i];}else{p[1] ^= arr[i];}}
}
int main()
{int arr[] = { 1,1,2,2,3,3,4,4,5,6 };int sz = sizeof(arr) / sizeof(arr[0]);int signal_dog[2] = { 0 };find_signal_dog(arr, sz, signal_dog);printf("%d %d", signal_dog[0], signal_dog[1]);return 0;
}

二、模拟实现atoi
1.atoi函数的功能
如下图所示,atoi的功能是将一个字符串转化为整型数字
2.模拟实现atoi
如何模拟实现atoi是一个难点
因为我们会遇到很多种情况
1.如果遇到空指针
2.如果遇到空字符串
3.如果遇到空白字符
4.如果遇到+-
5.如果遇到数据溢出
为了解决上面的问题,我们可以一点一点来思考,首先是空指针,我们直接使用断言即可
然后当我们遇到一个空字符串也就是''\0''的时候,我们可以直接返回0,但是这时候,我们会发现一个问题,这个0也有可能是正儿八经的'0'字符转化得到的,所以我们要进行区分
我们定义一个状态值。用来加以区分。我们默认是非法的数据
当我们遇到空白字符的时候,我们需要跳过这些空白字符,当我们遇到+- 的时候,我们就需要判断正负号了
处理完这些情况以后,就是正常的转化了,在转化的时候,我们先要保证str还有值,然后我们使用isdigit函数判断是否为数字字符,如果是,则直接转化,在转化的时候要注意越界,为了判断是否越界,我们将ret设置为longlong类型,这样就可以根据int的最大最小值进行判断了。处理好了以后,如果str所指向的为非数字字符,那么就是说,转化完成了,我们直接就可以返回这个ret了,这里的ret我们认为是非法的字符串转化得到的。最后当str遇到\0的时候,那么也是转化完成了,这样的转化我们认为是合法的。所以设置状态值为VALID,返回ret
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<ctype.h>
enum State
{VALID,INVALID
}state=INVALID;//默认是非法的
int my_atoi(const char* str)
{assert(str);if (str == '\0'){return 0;}//跳过空白字符while (isspace(*str)){str++;}//确认正负号int flag = 1;if (*str == '+'){flag = 1;str++;}if (*str == '-'){flag = -1;str++;}long long ret = 0;while (*str){if (isdigit(*str)){ret = ret*10 + flag * (*str - '0');if (ret > INT_MAX){return INT_MAX;}else if (ret < INT_MIN){return INT_MIN;}}else{return ret;}str++;}state = VALID;return (int)ret;
}
int main()
{char* p = "1234";int a = my_atoi(p);if (state == VALID){printf("%d\n", a);}else{printf("不合法的字符串:%d\n", a);}return 0;
}


本节内容就到这里
如果对你有帮助的话,不要忘记点赞加收藏哦!!!
想获得更多优质内容,一定要关注我哦!!!
相关文章:
【C语言刷题】找单身狗、模拟实现atoi
目录 一、找单身狗 1.暴力循环法 2.分组异或法 二、模拟实现atoi 1.atoi函数的功能 2.模拟实现atoi 一、找单身狗 题目描述:给定一个数组中只有两个数字是出现一次,其他所有数字都出现了两次。 编写一个函数找出这两个只出现一次的数字。 比如&…...
前端必会面试题指南
计算属性和watch有什么区别?以及它们的运用场景? // 区别computed 计算属性:依赖其它属性值,并且computed的值有缓存,只有它依赖的属性值发生改变,下一次获取computed的值时才会重新计算computed的值。watch 侦听器:…...
C 语言—— 数组
【C 语言】数组1. 概念2. 声明3. 分类4. 初始化5. 赋值6. 附加语法7. VLA 的一些补充1. 概念 数组是存放一组 相同类型 的 有序 数据的一段 连续 空间。 2. 声明 TYPE identifier[static(optional) qualifiers(optional) expression(optional)] TYPE identifier[qualifiers(o…...
Oracle-RAC集群主机重启问题分析
问题背景: 在对一套两节点Oracle RAC19.18集群进行部署时,出现启动数据库实例就会出现主机出现重启的情况,检查发现主机重启是由于节点集群被驱逐导致。 问题: 两节点Oracle RAC19.18集群,启动数据库实例会导致主机出现重启。 问题分析: 主机多次出现…...
Python每日一练(20230227)
目录 1. 路径交叉 ★★★ 2. 缺失的第一个正数 ★★★ 3. 寻找两个正序数组的中位数 ★★★ 附录 散列表 基本概念 常用方法 1. 路径交叉 给你一个整数数组 distance 。 从 X-Y 平面上的点 (0,0) 开始,先向北移动 distance[0] 米,然后向西移…...
Scratch少儿编程案例-算法练习-存款收益计算
专栏分享 点击跳转=>Unity3D特效百例点击跳转=>案例项目实战源码点击跳转=>游戏脚本-辅助自动化点击跳转=>Android控件全解手册点击跳转=>Scratch编程案例👉关于作者...
【Linux驱动开发100问】Linux驱动开发工程师在面试中常被问到的问题汇总
🥇今日学习目标:什么是Kconfig?如何使用Kconfig? 🤵♂️ 创作者:JamesBin ⏰预计时间:10分钟 🎉个人主页:嵌入式悦翔园个人主页 🍁专栏介绍:Lin…...
每日学术速递2.27
CV - 计算机视觉 | ML - 机器学习 | RL - 强化学习 | NLP 自然语言处理 Subjects: cs.CL 1.FiTs: Fine-grained Two-stage Training for Knowledge-aware Question Answering 标题:FiTs:用于知识感知问答的细粒度两阶段训练 作者:Qichen…...
【数据库系统概论】基础知识总结
🌹作者:云小逸 📝个人主页:云小逸的主页 📝Github:云小逸的Github 🤟motto:要敢于一个人默默的面对自己,强大自己才是核心。不要等到什么都没有了,才下定决心去做。种一颗树,最好的时间是十年前…...
简单移动平均在量化中的应用(附Python实战代码)
在大多数金融产品的投资过程中,均线系统都是很重要的投资参考。一般来说,均线可以近似理解为某段时间内成交筹码的均价,它往往能帮助我们找到合适的支撑位和压力位。随着各种技术流派以及统计学的发展,从简单移动平均中逐渐衍生出了更多的均线计算方式,比如指数移动平均、…...
ChatGPT提高你日常工作的五个特点,以及如何使用它来提高代码质量
ChatGPT已经完全改变了代码开发模式。然而,大多数软件开发者和数据专家们仍然不使用ChatGPT来完善——并简化他们的工作。 这就是我们在这里列出提升日常工作效率和质量的5个不同的特点的原因。 让我们一起来看看在日常工作中如何使用他们。 警告:不要…...
spark datasourceV1和v2
datasourceV2 一文理解 Apache Spark DataSource V2 诞生背景及入门实战 https://zhuanlan.zhihu.com/p/83006243 2.3 Data source API v2 https://issues.apache.org/jira/browse/SPARK-15689 Because of the above limitations/issues, the built-in data source impleme…...
10种聚类算法的完整python操作示例
大家好,聚类或聚类分析是无监督学习问题。它通常被用作数据分析技术,用于发现数据中的有趣模式,例如基于其行为的客户群。有许多聚类算法可供选择,对于所有情况,没有单一的最佳聚类算法。相反,最好探索一系…...
构建合作伙伴生态系统刻不容缓
合作伙伴关系管理(PRM)系统是否已死?向合作伙伴生态系统的转变将如何改变我们未来管理合作伙伴计划的方式? 自PC革命以来,间接销售和渠道营销一直普遍存在于技术领域,通过其他公司的销售团队和人脉来增加销售,是一种明…...
剑指 Offer 55 - I. 二叉树的深度(java解题)
剑指 Offer 55 - I. 二叉树的深度(java解题)1. 题目2. 解题思路3. 数据类型功能函数总结4. java代码1. 题目 输入一棵二叉树的根节点,求该树的深度。从根节点到叶节点依次经过的节点(含根、叶节点)形成树的一条路径&a…...
威胁行为者将旧漏洞武器化以发起勒索软件攻击
勒索软件运营商比以往任何时候都更加依赖未打补丁的系统来获得对受害者网络的初始访问权限。 一份新报告显示,攻击者正在互联网和暗网中积极搜索可用于勒索软件攻击的旧漏洞和已知漏洞。 其中许多缺陷已存在多年,对尚未修补或更新易受攻击系统的组织构…...
2023北京健博会/第十届中国国际大健康产博览会
China-DJK北京健博会,立足北京打造国内外大健康产业快速融合发展平台; 大健康时代:20年前没有健康产业,如今健康产业成了全球经济中唯“不缩水”的行业,早已被国际经济学界确定为“无限广阔的兆亿产业”。据机构数据&…...
Python学习笔记之环境搭建
Python学习笔记之环境搭建1. 下载Python2. Windows 安装最新Python3. Linux 安装最新PythonPython是一种编程语言,可以让您更快地工作并更有效地集成系统。 您可以学习使用Python,并立即看到生产力的提高和维护成本的降低。 Python是荷兰程序员吉多范罗苏…...
死锁的总结
哲学家死锁造成的原因:我有你需要的,但你已经有了 饥饿与死锁的区别 死锁一旦发生一定又饥饿现象,但是饥饿现象产生不一定是死锁 历史上对于死锁的声音 死锁的方案 前面两个都是不允许死锁出现 前面都是概念性的东西 后面我们研究如何破坏…...
强化学习RL 01~ 数学基础
目录 RL理解要点 1. RL数学基础 1.1 Random Variable 随机变量 1.2 概率密度函数 Probability Density Function(PDF) 1.3 期望 Expectation 1.4 随机抽样 Random Sampling 2. RL术语 Terminologies 2.1 agent、state 和 action 2.2 策略 policy π 2.3 奖励 reward …...
【Axure高保真原型】引导弹窗
今天和大家中分享引导弹窗的原型模板,载入页面后,会显示引导弹窗,适用于引导用户使用页面,点击完成后,会显示下一个引导弹窗,直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…...
云计算——弹性云计算器(ECS)
弹性云服务器:ECS 概述 云计算重构了ICT系统,云计算平台厂商推出使得厂家能够主要关注应用管理而非平台管理的云平台,包含如下主要概念。 ECS(Elastic Cloud Server):即弹性云服务器,是云计算…...
【WiFi帧结构】
文章目录 帧结构MAC头部管理帧 帧结构 Wi-Fi的帧分为三部分组成:MAC头部frame bodyFCS,其中MAC是固定格式的,frame body是可变长度。 MAC头部有frame control,duration,address1,address2,addre…...
如何在看板中有效管理突发紧急任务
在看板中有效管理突发紧急任务需要:设立专门的紧急任务通道、重新调整任务优先级、保持适度的WIP(Work-in-Progress)弹性、优化任务处理流程、提高团队应对突发情况的敏捷性。其中,设立专门的紧急任务通道尤为重要,这能…...
oracle与MySQL数据库之间数据同步的技术要点
Oracle与MySQL数据库之间的数据同步是一个涉及多个技术要点的复杂任务。由于Oracle和MySQL的架构差异,它们的数据同步要求既要保持数据的准确性和一致性,又要处理好性能问题。以下是一些主要的技术要点: 数据结构差异 数据类型差异ÿ…...
【生成模型】视频生成论文调研
工作清单 上游应用方向:控制、速度、时长、高动态、多主体驱动 类型工作基础模型WAN / WAN-VACE / HunyuanVideo控制条件轨迹控制ATI~镜头控制ReCamMaster~多主体驱动Phantom~音频驱动Let Them Talk: Audio-Driven Multi-Person Conversational Video Generation速…...
AI语音助手的Python实现
引言 语音助手(如小爱同学、Siri)通过语音识别、自然语言处理(NLP)和语音合成技术,为用户提供直观、高效的交互体验。随着人工智能的普及,Python开发者可以利用开源库和AI模型,快速构建自定义语音助手。本文由浅入深,详细介绍如何使用Python开发AI语音助手,涵盖基础功…...
水泥厂自动化升级利器:Devicenet转Modbus rtu协议转换网关
在水泥厂的生产流程中,工业自动化网关起着至关重要的作用,尤其是JH-DVN-RTU疆鸿智能Devicenet转Modbus rtu协议转换网关,为水泥厂实现高效生产与精准控制提供了有力支持。 水泥厂设备众多,其中不少设备采用Devicenet协议。Devicen…...
Vue3中的computer和watch
computed的写法 在页面中 <div>{{ calcNumber }}</div>script中 写法1 常用 import { computed, ref } from vue; let price ref(100);const priceAdd () > { //函数方法 price 1price.value ; }//计算属性 let calcNumber computed(() > {return ${p…...
相关类相关的可视化图像总结
目录 一、散点图 二、气泡图 三、相关图 四、热力图 五、二维密度图 六、多模态二维密度图 七、雷达图 八、桑基图 九、总结 一、散点图 特点 通过点的位置展示两个连续变量之间的关系,可直观判断线性相关、非线性相关或无相关关系,点的分布密…...





