【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 …...
如何通过League-Toolkit实现高效游戏辅助:从入门到精通的智能全攻略
如何通过League-Toolkit实现高效游戏辅助:从入门到精通的智能全攻略 【免费下载链接】League-Toolkit 兴趣使然的、简单易用的英雄联盟工具集。支持战绩查询、自动秒选等功能。基于 LCU API。 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit L…...
C++ 无原生 JSON 支持?一文实现通用序列化与反序列化封装方案
前言 在现代软件开发中,JSON(JavaScript Object Notation)因其轻量级和易读性成为数据交换的主流格式。C虽无原生JSON支持,但通过封装第三方库(如nlohmann/json),可高效实现序列化(…...
告别串口!STM32F105RCT6的ITM调试秘籍:从零配置到华为/高通项目级日志封装
STM32F105RCT6 ITM调试实战:企业级日志系统设计与性能优化 在嵌入式开发领域,调试效率直接影响项目进度和质量。传统串口调试方式虽然简单易用,但在处理复杂企业级项目时往往显得力不从心。本文将深入探讨基于STM32F105RCT6的ITM调试技术&…...
Unsloth让AI触手可及:免费GPU+开源框架,训练自己的模型
Unsloth让AI触手可及:免费GPU开源框架,训练自己的模型 1. Unsloth简介:高效微调的开源利器 Unsloth是一个专为大型语言模型(LLM)优化的开源微调框架,它的核心使命是让AI训练变得高效且易于获取。通过创新的技术手段,…...
FLUX.1-dev开源镜像部署教程:像素幻梦免配置环境3步快速上手
FLUX.1-dev开源镜像部署教程:像素幻梦免配置环境3步快速上手 1. 像素幻梦简介 像素幻梦(Pixel Dream Workshop)是一款基于FLUX.1-dev扩散模型构建的像素艺术生成工具。它采用独特的16-bit像素风格界面设计,为创作者提供沉浸式的AI绘图体验。 与传统AI…...
Janus-Pro-7B基础教程:CFG权重与图像多样性/保真度平衡策略
Janus-Pro-7B基础教程:CFG权重与图像多样性/保真度平衡策略 1. 认识Janus-Pro-7B多模态模型 Janus-Pro-7B是一个强大的统一多模态AI模型,它不仅能理解图片内容,还能根据文字描述生成高质量的图像。这个模型有74亿参数,支持图像描…...
RuView:无摄像头环境下人体姿态追踪的创新方法探索
RuView:无摄像头环境下人体姿态追踪的创新方法探索 【免费下载链接】RuView Production-ready implementation of InvisPose - a revolutionary WiFi-based dense human pose estimation system that enables real-time full-body tracking through walls using com…...
探索 COMSOL 三维多孔介质建模的魅力
comsol三维多孔介质 COMSOL三维多孔介质。 1.孔隙率孔径可控 2.一键区分固相孔相,简单方便 3.可设置五种粒径不同,含量不同的颗粒。嘿,各位科研和工程领域的小伙伴们!今天咱们来聊聊 COMSOL 里的三维多孔介质建模,这玩…...
一键解决中文文献管理痛点:茉莉花插件让Zotero效率提升90%的完整指南
一键解决中文文献管理痛点:茉莉花插件让Zotero效率提升90%的完整指南 【免费下载链接】jasminum A Zotero add-on to retrive CNKI meta data. 一个简单的Zotero 插件,用于识别中文元数据 项目地址: https://gitcode.com/gh_mirrors/ja/jasminum …...
Llama-3.2V-11B-cot效果展示:‘打字机式’CoT推演过程动态演示
Llama-3.2V-11B-cot效果展示:‘打字机式’CoT推演过程动态演示 1. 项目概述 Llama-3.2V-11B-cot是基于Meta Llama-3.2V-11B多模态大模型开发的高性能视觉推理工具。这款工具针对双卡RTX 4090环境进行了深度优化,特别修复了视觉权重加载的关键Bug&#…...





