单身狗1和单身狗2(C语言版)

news2024/11/19 22:40:57

目录

1. 单身狗1

2. 单身狗2


1. 单身狗1

题目:

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

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

例如:有数组的元素是:1,2,3,4,5,1,2,3,4,6。只有5和6只出现1次,要找出5和6。

第一种方法:暴力解题法(枚举法)

这种方法就不细致讲解了,代码就能说明方法了

#include<stdio.h>
#include<stdlib.h>
//第一种方法:暴力解法
//枚举法:直接用计数器的方式,找到该数字
int find_single_dog1(int arr[], int sz) {
	int num = 0;//作为标记,记录每位元素出现的次数
	int* count = (int*)malloc(sz * sizeof(arr[0]));//记录每位元素出现的次数,然后存储起来
	for (int i = 0;i < sz;i++) {
		for (int j = 0;j < sz;j++) {
			if (arr[i] == arr[j])
				num++;
		}
		count[i] = num;
		num = 0;
	}
	for (int i = 0;i < sz;i++) {
		if (count[i] == 1)
			return arr[i];
	}
	return -1;
}

int main() {
	int a[] = { 1,2,3,4,5,1,2,3,4 };
	int n = find_single_dog1(a, 9);
	printf("%d", n);
    return 0;
}

 第二种方法:用异或解题

//第二种:用异或解题
int find_single_dog1(int arr[], int sz) {
	int n = 0;
	for (int i = 0;i < sz;i++) {
		n ^= arr[i];
	}
	return n;
}

int main() {
	int a[] = { 1,2,3,4,5,1,2,3,4 };
	int n = find_single_dog1(a, 9);
	printf("%d", n);
	return 0;
}

2. 单身狗2

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

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

例如:有数组的元素是:1,2,3,4,5,1,2,3,4,6。只有5和6只出现1次,要找出5和6。

第一种方法:暴力解题法(枚举法)

这种方法就不细致讲解了,代码就能说明方法了

//第一种方法:暴力求解法
int* find_single_dog_first(int arr[], int sz) {
	int* find = (int*)malloc(sz * sizeof(arr[0]));//创建一个标识数组
	int* re = (int*)malloc(2 * sizeof(arr[0]));//创建一个返回数组
	int flag = -1;//自己也算一次,当只有自己,flag结果为0
	for (int i = 0;i < sz;i++) {
		for (int j = 0;j < sz;j++) {
			if (arr[i] == arr[j])
				flag++;
		}
		find[i] = flag;
		flag = -1;
	}
	int num = 0;//记录re的下标
	for (int i = 0;i < sz;i++) {
		if (find[i] == 0) {
			re[num] = arr[i];
			num++;
		}
	}
	return re;
}

int main() {
	int arr1[] = { 1,2,3,4,5,1,2,3,4,6};
	int sz = sizeof(arr1) / sizeof(arr1[0]);
	int* ret = find_single_dog_first(arr1, sz);
	for (int i = 0;i < 2;i++) {
		printf("%d ", ret[i]);
	}
	return 0;
}

第二种方法:用异或解题

 

//第二种方法:用异或的思想解题
//因为该题要返回两个int型的数据,但是函数返回只能返回一个数
//所以传入指针ps1和指针ps2来让计算后的数据能传到主函数main
void find_single_dog2(int arr[], int sz, int* ps1, int* ps2) {
	int r = 0;
	//1. 全部异或在一起,找出哪个位置为一
	for (int i = 0;i < sz;i++) {
		r ^= arr[i];
	}
	//2. 计算出哪个位置的数字1,用&运算符
	int pos = 0;//记录哪个位置为1
	for (int i = 0;i < 32;i++) {//因为r是int类型,有32位
		if (((r >> i) & 1) == 1) {
			pos = i;
			break;
		}
	}
	//3. 分组找出两个单身狗,并返回值
	for (int i = 0;i < sz;i++) {
		if (((arr[i] >> pos) & 1) == 1) {
			(*ps1) ^= arr[i];
		}
		else {
			(*ps2) ^= arr[i];
		}
	}
}

int main() {
	int arr[] = { 1,2,3,4,5,1,2,3,4,6 };
	int sz = sizeof(arr) / sizeof(arr[0]);
	int ps1 = 0;
	int ps2 = 0;
	find_single_dog2(arr, sz, &ps1, &ps2);
	printf("两个单身狗分别为:%d 和 %d", ps1, ps2);
	return 0;
}

 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

输入/输出的实用性-SOLIDWORKS 2024新功能

导出为 Extended Reality 您可以将 SOLIDWORKS CAD 文件导出为 .glb 或 .gltf 文件格式。 文件包含以下信息&#xff0c;例如几何体、外观、纹理、动画、运动算例、配置、显示状态、爆炸视图、光源 和元数据。对于大文件&#xff0c;导出支持 Draco&#xff0c;这是 .glb 和 .…

ChatGPT对于留学生论文写作有哪些帮助?

2022年11月&#xff0c;OpenAI公司的智能聊天产品ChatGPT横空出世&#xff0c;并两个月之内吸引了超过1亿用户&#xff0c;打破了TikTok&#xff08;抖音国际版&#xff09;9个月用户破亿的纪录。 划时代的浪潮 ChatGPT的火爆立即引起了全球关注并成为热门话题&#xff0c;它…

Mysql 内外链接,索引,事务,用户管理以及用C语言链接Mysql

文章目录 内外链接索引索引的相关操作全文索引 事务事务的操作事务的隔离级别隔离级别3个记录隐藏列字段 用户管理权限修改 使用C语言链接数据库 内外链接 两张表直接做笛卡尔积为内连接&#xff0c;之前使用的都是内连接 两张表&#xff1a;stu和exam 将两张表进行连接&…

Arya碎碎念 | 我的创作纪念日——写在成为创作者的第1095天

前言 打开博客创作者页面&#xff0c;发现CSDN发送过来一条私信&#xff0c;提醒我3年前发了第一篇博客。3年的时间里&#xff0c;大家都经历了很多事情&#xff0c;疫情 . . . . . 本篇博客是一些碎碎念&#xff0c;作为一个成为1095天创作者的纪念博客。 一、个人优质博客汇…

I2C的硬件实现

因为I2C是同步的&#xff0c;所以相对来说I2C更好用软件来实现&#xff0c;硬件却相对来说没这么好&#xff0c;但是硬件I2C通信也是有其优点的 我们是通过软件写入控制寄存器CR和数据寄存器DR&#xff0c;读取状态寄存器SR来了解外设电路当前处于什么状态&#xff0c;来实现I…

jvm实现的锁优化

目录 轻量级锁 轻量级锁的工作流程 轻量级锁的解锁 偏向锁 偏向锁的流程&#xff1a; 偏向锁和轻量级锁机区别&#xff1a; 其他优化 自旋锁和自适应自旋锁 锁消除 锁粗化 轻量级锁 “轻量级” 是相对于使用操作系统互斥量来实现的传统锁而言的&#xff0c;因此传统的…

Java学习笔记(四)——程序控制结构

一、顺序控制 二、分支控制 &#xff08;一&#xff09;单分支 &#xff08;二&#xff09;双分支 &#xff08;三&#xff09;多分支 &#xff08;四&#xff09;嵌套分支 &#xff08;五&#xff09;switch分支结构 &#xff08;六&#xff09;if和switch的选择 三、循…

Android Studio快速实现Flutter应用的国际化和多语言支持

文章目录 Flutter实现国际化和多语言支持添加依赖库Android Studio 安装flutter Intl插件项目初始化增加语言app中使用国际化在应用中切换语言&#xff1a;运行应用 总结easy_localization 插件intl 包Flutter GetX 包flutter_i18n 插件JSON 文件 Flutter实现国际化和多语言支持…

利用ArcGIS获取每一个冰川的中心位置经纬度坐标:要素转点和要素折点转点的区别

问题概述&#xff1a;下图是天山地区的冰川的分布&#xff0c;我们可以看到每一条冰川是一个面要素&#xff0c;要求得到每一个冰川&#xff08;面要素&#xff09;的中心经纬度坐标。 1.采用要素转点功能 选择工具箱的【数据管理工具】-【要素】-【要素转点】。完成之后再采用…

疯狂堆料!技嘉钛雕Z790 AORUS PRO X主板图赏

技嘉推出了钛雕Z790 AORUS PRO X主板。 现在这款新品已经来到了我们评测室&#xff0c;下面为大家带来图赏。 技嘉钛雕Z790 AORUS PRO X主板采用新一代超耐久显卡插槽&#xff0c;约58KG承重能力、内衬保护显卡PCB。 其采用1812相供电设计&#xff0c;4根双通道DDR5内存插槽&am…

药物滥用第四篇介绍

OXY&#xff1a; 羟考酮&#xff08;Oxycodone&#xff0c;OXY&#xff09;&#xff0c;分子式为C18H21NO4&#xff0c;是一种半合成的蒂巴因衍生物。羟考酮为半合成的纯阿片受体激动药&#xff0c;其作用机制与吗啡相似&#xff0c;主要通过激动中枢神经系统内的阿片受体而起镇…

FastAdmin框架实现数据表的增删改查

目录 简介 增加数据 修改数据 控制器&#xff08;controller&#xff09;代码&#xff1a; 查询数据 控制器&#xff08;controller&#xff09;代码&#xff1a; 模型&#xff08;model&#xff09;代码&#xff1a; 删除数据 控制器&#xff08;controller&#xff0…

2023年农村市场风口新商机:互联网+认养模式商业模式解析

背景&#xff1a;随着城市化进程的不断加快&#xff0c;人们对物质生活的要求和品质日益增高&#xff0c;特别是在疫情过亲身经历过病痛的折磨后&#xff0c;大家对自己的更加爱惜了&#xff0c;今天&#xff0c;微三云营销总监胡佳东发现一套2023年创业新项目新商机&#xff1…

选型销售管理软件要注意哪些问题?

近些年来&#xff0c;创新型企业大量涌现成为国内经济增长的新动能。同时管理者发现很快就遇到了发展瓶颈&#xff0c;为了保证业务的快速开展&#xff0c;引入销售管理软件的需求十分强烈。那么&#xff0c;选型销售管理软件要注意哪些问题? 一、直指痛点的功能 对于多数企…

APP开发成本的影响因素

在温州或中国任何地方开发APP的成本取决于多个因素&#xff0c;包括应用的规模、功能、设计、复杂性以及所需的技术和人力资源。以下是一些可能影响APP开发成本的主要因素&#xff0c;希望对大家有所帮助。北京木奇移动技术有限公司&#xff0c;专业的软件外包开发公司&#xf…

风电机浪涌保护器的防雷作用和意义

风电是一种利用风能转化为电能的清洁新能源&#xff0c;具有节约资源、减少污染、降低碳排放等优点。随着风电技术的发展和应用&#xff0c;风电场的规模和数量也不断增加&#xff0c;为人类提供了可持续的电力供应。然而&#xff0c;风电场也面临着一些挑战和风险&#xff0c;…

KingBase库模式表空间和客户端认证(kylin)

库、模式、表空间 数据库 数据库基集簇与数据库实例 KES集簇是由单个KES实例管理的数据库的集合KES集簇中的库使用相同的全局配置文件和监听端口、共享相关的进程和内存结构同一数据库集簇中的进程、相关的内存结构统称为实例 数据库 数据库是一个长期存储在计算机内的、有…

PDF编辑阅读 PDF Expert v3.5.2

PDF Expert是由Readdle开发的一款专业的PDF编辑和阅读工具。它可以帮助用户在Mac、iPad和iPhone等设备上查看、注释、编辑、填写和签署PDF文档。 以下是PDF Expert的特点&#xff1a; PDF编辑&#xff1a;PDF Expert提供了丰富的PDF编辑功能&#xff0c;包括添加、删除、移动…

学习pytorch14 损失函数与反向传播

神经网络-损失函数与反向传播 官网损失函数L1Loss MAE 平均MSELoss 平方差CROSSENTROPYLOSS 交叉熵损失注意code 反向传播在debug中的显示code B站小土堆pytorch视频学习 官网 https://pytorch.org/docs/stable/nn.html#loss-functions 损失函数 L1Loss MAE 平均 import to…

2022年亚太杯APMCM数学建模大赛A题结晶器熔剂熔融结晶过程序列图像特征提取及建模分析求解全过程文档及程序

2022年亚太杯APMCM数学建模大赛 A题 结晶器熔剂熔融结晶过程序列图像特征提取及建模分析 原题再现&#xff1a; 连铸过程中的保护渣使钢水弯液面隔热&#xff0c;防止钢水在连铸过程中再次氧化&#xff0c;控制传热&#xff0c;为铸坯提供润滑&#xff0c;并吸收非金属夹杂物…