找单身狗与与“atoi”函数的模拟实现

本文介绍了如何使用位操作解决寻找数组中只出现一次的数字问题,以及模拟实现C语言的atoi函数,处理字符串到整数的转换。在位操作中,通过异或操作找出两个出现一次的数字;在模拟atoi函数时,处理了空指针、空白字符串、非数字字符等异常情况,确保转换的正确性。

1找单身狗

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

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

例如{1,2,3,4,5,1,2,3,4,6}找两条单身狗

这题最难的是咋分组?不知道各位听过按位异或没?就是两个二进制数进行异或,相同为0,相异为1。

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>

void fingle_dog(int a2[], int sz)
{
	int i = 0;
	int ret = 0;
	int dog1 = 0;
	int dog2 = 0;
	for (i = 0; i < sz; i++)
	{
		ret ^= a2[i];
	}
	//查找第几位是1
	int pos = 0;
	for (i = 0; i < 32; i++)
	{
		if (((ret >> i) & 1) == 1)
		{
			pos = i;
			break;
		}
	}

	for (i = 0; i < sz; i++)
	{
		if (((a2[i] >> pos) & 1) == 0)
		{
			dog1 ^= a2[i];
		}
	}
	dog2 = ret ^ dog1;
	printf("%d %d\n", dog1, dog2);
}


int main()
{
	int a1[] = { 1,2,3,4,5,1,2,3,4,6 };
	int sz = sizeof(a1) / sizeof(a1[0]);
	fingle_dog(a1, sz);
	return 0;
}

 2.atoi函数模拟实现

atoi 功 能: 将字符串转换成整型数;atoi()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负号才开始做转换,而再遇到非数字或字符串时('\0')才结束转化,并将结果返回(返回转换后的整型数)。

我们模拟时会遇到以下几个问题:

1.空指针;

2,空白字符串;

3.字符串为空;

4.正负号问题;

5.字符不是数字字符;

只要出现除了4其他情况,atoi函数就不能将数字字符转化为sh数字,所以我们定义一个判断状态的枚举类型,只有两种情况,正常和异常,我们先定义它是异常的,因为正常的情况少,容易修改。

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<assert.h>
#include<ctype.h>
#include<limits.h>
enum Status
{
	VALID,
	INVALID,
}status = INVALID;
//正常转化时是合法的VALID,其他情况都是非法,所以令它非法
int my_atoi(char* str)
{   //空指针
	assert(str);
	int flag = 1;
	//字符串为空
	if (str == '\0')
	{
		return 0;
	}
	//空白字符
	while (isspace(*str))//isspace判断是否为空白字符
		//空白字符是指在屏幕不会显示出来的字符
		//(如空格,制表符tab,回车换行等)
	{
		str++;//直接跳过
	}
	//正负号
	if (*str == '+')
	{
		flag = 1;
		str++;


	}
	else if (*str == '-')
	{
		flag = -1;
		str++;
	}
	long long n = 0;//整形可能存不下
	while (*str)//字符串还没结束
	{
		if (isdigit(*str))//判断是不是数字字符,头文件<ctype.h>
		{
			n = n * 10 + flag * (*str - '0');
			//是数字字符但是数值溢出
			if ((n < INT_MIN) || (n > INT_MAX))
			{
				n = 0;
				break;
			}


		}
		else//不是数字字符了(a,b,c等)
		{
			n = 0;
			break;
		}
		str++;
	}
	if (*str == '\0')
	{
		status = VALID;

	}
	return (int)n;
}


int main()
{
	char ch[] = "12345";
	int p = my_atoi(ch);
	if (status == VALID)
	{
		printf("合法返回:%d", p);
	}
	else
	{
		printf("非法返回:%d", p);
	}
}

注意n的类型是long long因为int的可能存储不下。

n = n * 10 + flag * (*str - '0');——要×flag因为这一步可以判断是正是负。

Delphi 12.3 作为一款面向 Windows 平台的集成开发环境,由 Embarcadero Technologies 负责其持续演进。该环境以 Object Pascal 语言为核心,并依托 Visual Component Library(VCL)框架,广泛应用于各类桌面软件、数据库系统及企业级解决方案的开发。在此生态中,Excel4Delphi 作为一个重要的社区开源项目,致力于搭建 Delphi Microsoft Excel 之间的高效桥梁,使开发者能够在自研程序中直接调用 Excel 的文档处理、工作表管理、单元格操作及宏执行等功能。 该项目以库文件组件包的形式提供,开发者将其集成至 Delphi 工程后,即可通过封装良好的接口实现对 Excel 的编程控制。具体功能涵盖创建编辑工作簿、格式化单元格、批量导入导出数据,乃至执行内置公式宏指令等高级操作。这一机制显著降低了在财务分析、报表自动生成、数据整理等场景中实现 Excel 功能集成的技术门槛,使开发者无需深入掌握 COM 编程或 Excel 底层 API 即可完成复杂任务。 使用 Excel4Delphi 需具备基础的 Delphi 编程知识,并对 Excel 对象模型有一定理解。实践中需注意不同 Excel 版本间的兼容性,并严格遵循项目文档进行环境配置依赖部署。此外,操作过程中应遵循文件访问的最佳实践,例如确保目标文件未被独占锁定,并实施完整的异常处理机制,以防数据损毁或程序意外中断。 该项目的持续维护依赖于 Delphi 开发者社区的集体贡献,通过定期更新以适配新版开发环境 Office 套件,并修复已发现的问题。对于需要深度融合 Excel 功能的 Delphi 应用而言,Excel4Delphi 提供了经过充分测试的可靠代码基础,使开发团队能更专注于业务逻辑用户体验的优化,从而提升整体开发效率软件质量。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论 8
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值