你是真的“C”——找单身狗~

简介: 初阶——找单身狗问题:在一组数组中,有一只“单身狗”(该数字只出现一次),其他的数字都有一个和自己相同的数字。其实解答此题有许多的方法,例如直接将数组进行一个排序,然后定义两个指针,然后寻找到单身狗。这里介绍的是用异或运算来解答这道题目,效率也比较高。

微信图片_20230427214238.gif

😎博客昵称:博客小梦

😊最喜欢的座右铭:全神贯注的上吧!!!

😊作者简介:一名热爱C/C++,算法等技术、喜爱运动、热爱K歌、敢于追梦的小博主!

😘博主小留言:哈喽!😄各位CSDN的uu们,我是你的博客好友小梦,希望我的文章可以给您带来一定的帮助,话不多说,文章推上!欢迎大家在评论区唠嗑指正,觉得好的话别忘了一键三连哦!😘微信图片_20230427160707.gif

前言🙌


   哈喽各位友友们😊,我今天又学到了很多有趣的知识,现在迫不及待的想和大家分享一下!😘我仅已此文,和大家分享你是真的“C”——找单身狗~ 都是精华内容,可不要错过哟!!!😍😍😍


初阶——找单身狗问题:


在一组数组中,有一只“单身狗”(该数字只出现一次),其他的数字都有一个和自己相同的数字。


其实解答此题有许多的方法,例如直接将数组进行一个排序,然后定义两个指针,然后寻找到单身狗。这里介绍的是用异或运算来解答这道题目,效率也比较高


异或运算的规律:

  • 1.相同为零,相异为1;
  • 2.任何数和0异或等于其本身
  • 3.两个相同的数异或为0.


解题源码分享: 😘


#include <stdio.h>
int main()
{
  int single_dog[] = { 1,2,3,4,1,2,3,4,5 };
  int sz = sizeof(single_dog) / sizeof(int);
  int i = 0;
  int sin_dog = 0;
  for (i = 0; i < sz; i++)
  {
    sin_dog^= single_dog[i];
  }
  printf("%d", sin_dog);
  return 0;
}


程序输出结果验证: 😊


微信图片_20230428185427.png


进阶——找单身狗问题:


在一组数组中,有两只“单身狗”(有两个数字只出现一次),其他的数字都有一个和自己相同的数字。


  • 1.这道题明显比初阶找单身狗的问题难度明显上升,但是解法也很相似。
  • 2.那我们可不可以将这个问题转换成初阶单身狗问题呢?显然是可以的。这道题的核心就是进行一个分组,让两只单身狗分别在不同的组里面。这里举例说明一下两只单身狗为4和5。
  • 3.我们知道 4 的 二进制为:0100 。 5 的二进制为: 0101。可以发现 4 和 5 的最低二进制位上的数字不同。因此,这个可以作为分组的条件。
  • 4.然后依次对每一个组的数字进行一个异或,最终得到每一组的单身狗。


解题源码分享: 😘


#include <stdio.h>
int main()
{
  int single_dog[] = {1,2,3,4,1,2,3,5};
  int sz = sizeof(single_dog) / sizeof(int);
  int i = 0;
  int dog1 = 0;
  int dog2 = 0;
  for (i = 0; i < sz; i++)
  {
    //分组:
    // 4 : 0100  5: 0101 
    if ((single_dog[i] & 1) == 1)
    {
      dog1 ^= single_dog[i];
    }
    else if((single_dog[i] & 1) == 0)
    {
      dog2 ^= single_dog[i];
    }
  }
  printf("%d %d", dog1, dog2);
  return 0;
}


程序输出结果验证: 😊


微信图片_20230428185511.png


总结撒花💞


   本篇文章旨在分享你是真的“C”——找单身狗。希望大家通过阅读此文有所收获😘如果我写的有什么不好之处,请在文章下方给出你宝贵的意见😊。如果觉得我写的好的话请点个赞赞和关注哦~😘😘😘

相关文章
|
机器学习/深度学习 人工智能 自然语言处理
【LangChain系列】第五篇:大语言模型中的提示词,模型及输出简介及实践
【5月更文挑战第19天】LangChain是一个Python库,简化了与大型语言模型(LLM)如GPT-3.5-turbo的交互。通过ChatOpenAI类,开发者可以创建确定性输出的应用。提示词是指导LLM执行任务的关键,ChatPromptTemplate允许创建可重用的提示模板。输出解析器如StructuredOutputParser将模型的响应转化为结构化数据,便于应用处理。LangChain提供可重用性、一致性、可扩展性,并有一系列预建功能。它使得利用LLM构建复杂、直观的应用变得更加容易。
798 0
|
机器学习/深度学习 搜索推荐 数据可视化
基于神经网络嵌入的推荐系统:利用深度学习和维基百科构建图书推荐系统
快来利用深度学习和维基百科构建一个属于你自己的图书推荐系统吧,手把手教学,够简单够酷炫。
3122 0
|
2天前
|
数据采集 人工智能 安全
|
11天前
|
云安全 监控 安全
|
3天前
|
自然语言处理 API
万相 Wan2.6 全新升级发布!人人都能当导演的时代来了
通义万相2.6全新升级,支持文生图、图生视频、文生视频,打造电影级创作体验。智能分镜、角色扮演、音画同步,让创意一键成片,大众也能轻松制作高质量短视频。
1023 151
|
3天前
|
编解码 人工智能 机器人
通义万相2.6,模型使用指南
智能分镜 | 多镜头叙事 | 支持15秒视频生成 | 高品质声音生成 | 多人稳定对话
|
17天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
1720 9
|
8天前
|
人工智能 自然语言处理 API
一句话生成拓扑图!AI+Draw.io 封神开源组合,工具让你的效率爆炸
一句话生成拓扑图!next-ai-draw-io 结合 AI 与 Draw.io,通过自然语言秒出架构图,支持私有部署、免费大模型接口,彻底解放生产力,绘图效率直接爆炸。
662 152
|
10天前
|
人工智能 安全 前端开发
AgentScope Java v1.0 发布,让 Java 开发者轻松构建企业级 Agentic 应用
AgentScope 重磅发布 Java 版本,拥抱企业开发主流技术栈。
626 14