首页 > 其他分享 >C:每日一题:单身狗

C:每日一题:单身狗

时间:2024-08-15 22:26:28浏览次数:6  
标签:sz arr 数组 int 每日 re 异或 单身

​​​​

一、题目:

在一个整型数组中,只有一个数字出现一次,其他数组都是成对出现的,请找出那个只出现一次的数字。

整型数组 int arr[ ] = {1,1,2,2,3,4,4}

二、思路分析:

1.,明确目标,选择合适的算法

我们需要在数组中找出单个出现的数字;由于相同数字异或的结果为 0 ,而任何数字与 0 异或都得到其本身。可以通过对数组中所有数字进行异或操作,最终得到的结果就是只出现一次的数字。

2.考虑可能存在的bug

数组可能为空数组或者所求元素个数为负数的情况

if (sz <= 0 || arr == NULL)

3.设计一个函数来完成计算数组中出现一次的元素

三、自定义函数number作用

int number(int arr[], int sz)
{
	if (sz <= 0 || arr == NULL)//防止数组为空或者非法的情况
	{
		printf("输入错误!\n");
		return -1;
	}
	int re = 0;
	int i = 0;
	for(i = 0;i<sz;i++)
	{
		re ^= arr[i];
	}
	return re;
}

number函数的作用是:

  • 通过条件判断 sz <= 0 || arr == NULL 来确保输入的数组不是空数组或者不存在的。如果是,就打印错误提示并返回 -1 。
  • 使用一个循环遍历数组的每个元素。通过异或操作 来计算。由于相同的数异或结果为 0 ,而任何数与 0 异或都得到其本身,所以最终异或操作 re ^= arr[i]; 的结果就是数组中只出现一次的元素。

四:主函数main的作用

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

	int single = number(arr, sz);
	if (single != -1)
	{
		printf("%d 是单身狗", single);
	}
	return 0;
}

main作用是:

  • 定义了整数数组 arr 并初始化。
  • 通过 sizeof 操作计算数组的大小并存储在sz 中。
  • 调用  number 函数来计算数组中只出现一次的元素,并将结果存储在single  中。
  • 通过条件判断 single != -1;,如果计算成功(即不是因为输入错误返回的 -1 ),就打印出结果并说明是“单身狗”。

五:解析代码 re ^= arr[i]

re ^= arr[i]  就等于 re = re ^ arr[i]

^异或运算重要的两个性质:

  • 相同为0,相异为1;
  • 任何数与 0 进行异或运算结果为其本身。

举个例子: int arr[ ] = {1,1,2,3,3}

初始re = 0;

re = re ^ 1 = 1;此时re = 1;

re = re ^ 1 = 1 ^ 1 = 0;此时re = 0;

re = re ^ 2 = 0 ^ 2 = 2;此时re = 2;

re = re ^ 3 = 2 ^ 3 =0010 ^ 0011 = 0001=1(十进制),此时re = 1;

re = re ^ 3 = 1 ^ 3 =0001 ^ 0011 = 0010 = 2(十进制),re = 2;

所以单身狗是2.

这是因为成对出现的元素在异或过程中相互抵消为 0 ,而只出现一次的元素不会被抵消,最终就留在了 re  中。

六、完整代码及注释

#include <stdio.h>
int number(int arr[], int sz) 
{   
    if (sz <= 0 || arr == NULL)  // 检查输入的数组有误,若有误则打印错误信息并返回 -1
    {
        printf("输入错误!\n");
        return -1;
    }
    int re = 0;  // 用于存储异或运算的结果
    int i = 0;  
    for (i = 0; i < sz; i++) // 遍历数组进行异或运算
    {
        re ^= arr[i];  // 每次将当前元素与 re 进行异或操作
    }
    return re;  // 返回最终的异或结果,即为只出现一次的数字
}
int main() 
{
    int arr[] = {1,2,3,4,5,1,2,3,4,5,6};
    int sz = sizeof arr / sizeof(arr[0]);  // 计算数组的大小
    int single = number(arr, sz);  // 调用函数计算只出现一次的数字
    if (single!= -1) // 如果计算结果不为 -1,即输入合法且找到了只出现一次的数字,进行输出
    {
        printf("%d 是单身狗", single);
    }
    return 0;
}

结果展示:

标签:sz,arr,数组,int,每日,re,异或,单身
From: https://blog.csdn.net/2401_85010100/article/details/141143120

相关文章

  • 高级java每日一道面试题-2024年8月15日-设计模式篇-设计模式与面向对象原则的关系是什
    如果有遗漏,评论区告诉我进行补充面试官:设计模式与面向对象原则的关系是什么?我回答:在设计模式与面向对象原则的关系中,两者紧密相连且相互促进。面向对象的原则为设计模式的形成提供了理论基础和指导思想,而设计模式则是这些原则在特定问题域中的具体实践和实现方式。下......
  • LeetCode每日一题----特殊数组二
    解析:1.int[]nums:一个整数数组。2.int[][]queries:一个二维整数数组,每个一维数组包含两个整数,表示查询的范围。该方法的主要功能是根据给定的nums数组和一系列查询queries,判断每个查询区间[queries[i][0],queries[i][1]]内的元素是否都具有相同的奇偶性。返回一个布......
  • 每日一题:Leetcode-662 二叉树最大宽度
    力扣题目解题思路java代码力扣题目:给你一棵二叉树的根节点 root ,返回树的 最大宽度 。树的 最大宽度 是所有层中最大的 宽度 。每一层的 宽度 被定义为该层最左和最右的非空节点(即,两个端点)之间的长度。将这个二叉树视作与满二叉树结构相同,两端点间会出现一些......
  • 高级java每日一道面试题-2024年8月12日-设计模式篇-请列举出在JDK中几个常用的设计模
    如果有遗漏,评论区告诉我进行补充面试官:请列举出在JDK中几个常用的设计模式?我回答:在JavaDevelopmentKit(JDK)中,许多设计模式被广泛使用,以帮助实现软件的结构、行为和复用。下面是一些在JDK中常见的设计模式及其简要说明:工厂模式(FactoryPattern)JDK中的java......
  • 每日AI必读资讯 2024-08-12
    原文链接:https://blog.csdn.net/m0_46163918/article/details/14111374601黑匣子被打开了!能玩的Transformer可视化解释工具:TransformerExplainer佐治亚理工学院和IBM研究院开发一款基于web的开源交互式可视化工具「TransformerExplainer」,帮助非专业人士了解Transfor......
  • 【每日刷题】Day98
    【每日刷题】Day98......
  • 2024/08/11 每日一题
    LeetCode1035不相交的线方法1:动态规划classSolution{publicintmaxUncrossedLines(int[]nums1,int[]nums2){intn=nums1.length,m=nums2.length;int[][]dp=newint[n+1][m+1];for(inti=1;i<=n;i++){......
  • GitHub每日最火火火项目(8.9)
    项目名称:bghira/SimpleTuner项目介绍:SimpleTuner是一个通用的微调工具包,主要面向StableDiffusion2.1、StableDiffusion3、DeepFloyd和SDXL等模型。它旨在为这些模型提供一种便捷的微调方式,以适应不同的应用场景和需求。通过SimpleTuner,用户可以调整模型的参数,提高模......
  • Java每日一练06
    这里写目录标题一级目录二级目录三级目录题目1.一般情况下,以下哪个选项不是关系数据模型与对象模型之间匹配关系?2.transient变量和下面哪一项有关?3.线程安全的map在JDK1.5及其更高版本环境有哪几种方法可以实现?4.使用mvc模式设计的web应用程序具有以下优点,除了?5.......
  • 2024/08/10 每日一题
    LeetCode2940找到Alice和Bob可以相遇的建筑方法1:线段树classSolution{staticint[]tree;//存储区间的最大值staticvoidbuild(into,intleft,intright,int[]datas){if(left==right){tree[o]=datas[left-1];......