【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 …...
ArcGIS Server 10.8.1 要素服务发布实战:从PostgreSQL数据库到Web地图的完整链路
ArcGIS Server 10.8.1 要素服务全链路实战:PostgreSQL数据发布与Web集成深度指南 当空间数据从静态文件走向动态服务,要素服务(Feature Service)正在重塑现代GIS应用的交互范式。本文将带您深入探索如何将PostgreSQL中的空间数据转…...
构建多平台博客数据分析工具:从数据聚合到可视化实践
1. 项目概述:一个为博主量身定制的流量与内容分析工具最近在折腾个人博客和内容创作的朋友,大概都绕不开一个核心问题:我写的东西,到底有多少人看?读者从哪里来?他们对什么内容更感兴趣?如果你在…...
基于NeoKey Trinkey的智能媒体控制器:从电容触摸到USB HID实战
1. 项目概述:从一块小板子到桌面交互神器如果你和我一样,桌上堆满了各种开发板,那么第一次看到Adafruit的NeoKey Trinkey时,大概率会觉得它“平平无奇”——一块比大拇指指甲盖大不了多少的板子,集成了一个机械按键、一…...
TFT:一个可解释的变换器
原文:towardsdatascience.com/tft-an-interpretable-transformer-70147bcf6212 简介 世界上每家公司都需要预测来规划其运营,无论它们在哪个行业运营。公司中有几个预测用例需要解决,例如,年度计划的销售,每月计划的语…...
Perplexity APA格式生成漏洞深度审计(2024实测版):92.6%用户忽略的DOI与作者名缩写陷阱
更多请点击: https://intelliparadigm.com 第一章:Perplexity APA格式生成漏洞深度审计(2024实测版):92.6%用户忽略的DOI与作者名缩写陷阱 APA第7版核心校验失效现象 Perplexity 在2024年Q2版本中仍沿用过时的APA引用…...
【ITIL4】32服务实践 - 问题管理(Problem Management)
【ITIL4】32服务实践 - 问题管理(Problem Management) 文章目录【ITIL4】32服务实践 - 问题管理(Problem Management)一、核心定义1. 问题(Problem)2. 已知错误(Known Error)3. 变通…...
保姆级避坑指南:在Win10上用VS2013+CUDA8.0搞定BundleFusion与RealSense D435i联调
Win10环境下的BundleFusion与RealSense D435i深度联调实战手册 当三维重建技术遇上老旧开发环境,就像让一位现代外科医生使用上世纪的手术器械——理论可行,但实操处处是坑。本文将带您穿越这片技术雷区,用VS2013和CUDA8.0这套"复古装备…...
书匠策AI:一个让你“毕业不秃头“的论文神器,到底藏了什么黑科技?
各位同学,先做个灵魂拷问:你有没有在凌晨三点对着空白的Word文档,大脑一片空白,感觉自己不是在写论文,而是在跟一堵墙对视? 别慌,今天给你们安利一个我最近挖掘到的"论文外挂"——书…...
基于GPT的学术论文智能阅读工具:ChatGPT-Paper-Reader实战指南
1. 项目概述与核心价值如果你和我一样,经常需要阅读大量的学术论文,尤其是那些动辄十几页、公式图表密布的PDF文件,那你一定体会过那种“望文生畏”的感觉。一篇论文的核心创新点、实验细节、数据对比,往往散落在各个章节…...
遥感在生态系统碳储量、碳收支、碳循环、碳汇稳定性预警以及人为源排放反演等应用
卫星遥感具有客观、连续、稳定、大范围、重复观测的优点,已成为监测全球碳盘查的核心技术手段,卫星遥感也正在成为新一代、国际认可的全球碳核查业务化方法。本此目的就是梳理碳中和及碳盘点对卫星遥感的最新现实需求,系统总结遥感技术在生态…...





