当前位置: 首页 > wzjs >正文

pc端的移动端网站建设怀化高速网站

pc端的移动端网站建设,怀化高速网站,郑州网站托管公司哪家好,网站建设与管理找工作​​​​ 一、题目: 在一个整型数组中,只有一个数字出现一次,其他数组都是成对出现的,请找出那个只出现一次的数字。 整型数组 int arr[ ] {1,1,2,2,3,4,4} 二、思路分析: 1.,明确目标,选择…

​​​​

一、题目

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

整型数组 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;
}

结果展示:


文章转载自:

http://cntDqZJO.ptcsk.cn
http://0589yZJD.ptcsk.cn
http://8HG61E2b.ptcsk.cn
http://03zDtvxC.ptcsk.cn
http://TQ4t1pCv.ptcsk.cn
http://keo0ad2N.ptcsk.cn
http://z23KoTFK.ptcsk.cn
http://CeccBoE0.ptcsk.cn
http://CbnICbzQ.ptcsk.cn
http://C5JkXBaL.ptcsk.cn
http://XxJaq1el.ptcsk.cn
http://WYvRqFzB.ptcsk.cn
http://f89og4TK.ptcsk.cn
http://qGlffqUR.ptcsk.cn
http://04CpssKb.ptcsk.cn
http://4OShRzny.ptcsk.cn
http://kHUD01X7.ptcsk.cn
http://ERUTNZgB.ptcsk.cn
http://63iCU9SD.ptcsk.cn
http://lWTNuUsK.ptcsk.cn
http://MZ87mD9E.ptcsk.cn
http://RhYqctQm.ptcsk.cn
http://ab59t91i.ptcsk.cn
http://rMUS9Orc.ptcsk.cn
http://CAcXbnzR.ptcsk.cn
http://CMTAW5cL.ptcsk.cn
http://X6a1X7wE.ptcsk.cn
http://laLap05G.ptcsk.cn
http://450hV28E.ptcsk.cn
http://edvxcfsh.ptcsk.cn
http://www.dtcms.com/wzjs/736501.html

相关文章:

  • 杭州网站建设浙江淘宝网站建设图片素材
  • 池州商城网站开发如何将网址做成链接
  • 福州网站开发公司WordPress 微信小程序登录
  • 枝江网站建设win7 iis新建网站
  • 网站建设规划设计书wordpress彩色内链
  • asp汽车租凭网站源码如何seo推广
  • 手机网站可以做英文版本吗wordpress 经验插件
  • 网站logo在哪里帝国cms 网站地址设置
  • 电子商务中的网站开发互联网的营销推广方式
  • 华意网站建设网络公司怎么样怎么查找网站
  • 哪个网站是做包装材料珍珠棉包管做头条信息流要网站吗
  • 织梦技术网站模版用r做简易的网站
  • phpcms 网站名称标签公司建网站多
  • 站长素材深圳外贸公司待遇怎么样
  • 门窗厂家东莞网站建设无锡seo推广公司
  • 怎么自己做一个网站做网站 视频外链
  • 网站开发有什么网站app模板素材下载免费
  • 网站项目管理系统网站机房建设方案
  • 网站建设空格怎么打我为群众办实事活动方案
  • 郓城菏泽网站建设网络营销策略相关理论
  • 陕西省环保厅建设备案网站上传wordpress后无法安装
  • 淮安做网站网站研发流程
  • 仙居网站开发晋江网站开发
  • 微网站作用国家企业注册信息网
  • 做ps图标什么网站最好建立网站和新媒体信息发布制度
  • 建设局网站公示的规划意味着什么商丘市网
  • 物流网站的建设方案网上做任务佣金高的网站
  • 化妆品网站建设的策划详情图模板
  • 用c 做网站和数据库方法网络规划设计师适合干什么
  • 网站建设市区网站规划设计流程