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

wordpress和公众号对接沧州网站seo

wordpress和公众号对接,沧州网站seo,秦皇岛中兵建设集团网站,提升网站知名度这里写目录标题 问题详情分析问题代码展示 问题详情 剑指 Offer 56: 一个整型数组 nums 里除两个数字之外,其他数字都出现了两次。请写程序找出这两个只出现一次的数字。要求时间复杂度是O(n),空间复杂度是O(1)。 示例: 输入&a…

这里写目录标题

  • 问题详情
  • 分析问题
  • 代码展示

问题详情

剑指 Offer 56:

一个整型数组 nums 里除两个数字之外,其他数字都出现了两次。请写程序找出这两个只出现一次的数字。要求时间复杂度是O(n),空间复杂度是O(1)。

示例:

输入:nums = [4,1,4,6]
输出:[1,6] 或 [6,1]

分析问题

首先我们知道两个相同的数异或结果是0,而0异或任何数都是不变的;,而且异或运算是支持交换律和结合律;

C语言中的异或符号是’^’

如:353=335=0^5=5;

那如果数组nums中只有一个数出现一次,其它的数都出现了两次,那我们将所有的数组元素进行异或运算,不就可以得出结果了吗?

但是,在这里有两个只出现一次的数字,我们该怎么办呢,如果我们也将其所有的数组元素都异或在一起,那得出的数是不是就是那两个出现一次的数字异或的结果:

例:[1,1,2,3,4,4,5,5]

2 = 0010;3 = 0011

所以1123445^5 = 023 = 0001 = 1

那我们能不能将这两个数分开来呢?使这两个单独出现的数在它们所在的数组都是单独存在的。再分别异或,就能得出这两个数。
在这里插入图片描述

那如何分出这两个数呢:

我们先把数组nums中所有元素异或起来。

1123445^5 = 023 = 0011^0010 = 0001

相同的数异或为0,0与非0数异或为非0数本身。 所以,全部异或在一起就等价于两个单独数异或.

异或得出值0001,设这个值为ret 。通过观察可以发现,ret为1的位,就说明两个单独数的相同位是不同的。要么是1要么是0。不可能重复。

那我们如何去找到为1的位:

我们定义一个变量m = 1;将1(00000000000000000000000000000001)不断地左移m位,与ret进行&运算,如果结果为非0,那此时,1对应的位就是1向左移m位对应1的位置:

在这里插入图片描述

回到刚刚的数组:通过这个为1的位,和原数组中所有元素进行&运算,就可以把两个单独出现的数分开。其他出现两次的数因为二进制值相同也会共同出现在同一边。

在这里插入图片描述

到这我们写出这个程序就不难了。

代码展示

int* singleNumbers(int* nums, size_t numsSize, int* returnSize) {int ret = 0;int i = 0;//保存单独出现的数异或在一起的值for (i = 0; i < numsSize; i++){ret ^= nums[i];}int m = 0;//从低向高位找到ret中第m位为1的位置, 为1代表异或在一起的两个数不相同。//while (m < 32){if (ret & (1 << m)){break;}else{m++;}}int x = 0;//记录单独出现的数int y = 0;//记录单独出现的数for (i = 0; i < numsSize; i++){if (nums[i] & (1 << m)) //&为1的为一组 直接全部异或到一起记录其值{x ^= nums[i];}else  //为0的为一组{y ^= nums[i];}}int* retArr = malloc(2 * sizeof(int));retArr[0] = x;retArr[1] = y;*returnSize = 2;return retArr;
}int main()
{int p = 0;int arr[] = { 1,2,55,55,66,66 };int* a = singleNumbers(arr, sizeof(arr) / sizeof(int), &p);printf("%d ", a[0]);printf("%d ", a[1]);free(a);a = NULL;printf("%d ", p);return 0;
}
http://www.tj-hxxt.cn/news/77629.html

相关文章:

  • 网钛cms做的网站文案短句干净治愈
  • b2b网站怎么做推广最近发生的新闻
  • 网站建设 资产软文写作的十大技巧
  • 智能硬件开发百度推广seo是什么意思
  • 建立一个商城网站百度怎么打广告
  • 企业做网站注意事项hao123网址导航
  • 怎样给网站做app外贸seo
  • 英文网站建设 济南海外广告投放渠道
  • 山西网站建设推荐百度竞价关键词价格查询工具
  • 正规的佛山网站建设价格口碑营销的前提及好处有哪些
  • 产品网页设计教程优化关键词可以选择哪个工具
  • htdocs wordpress北京seo优化诊断
  • 盐城seo快速排名东莞网站建设优化
  • 网站设计用什么字体好旅行网站排名前十名
  • 网站开发人员职能apple日本网站
  • 查工作单位的网站线上商城的推广方案
  • 苗木企业网站建设源代码免费com域名申请注册
  • 商业网站模板制作与开发微信广告
  • 宁波建设局网站首页湘潭网站设计
  • 做阀门销售在哪个网站上做好外贸接单十大网站
  • php做网站标题加链接seo管理
  • php做网站访问记录搜索引擎营销简称为
  • 北京 做网站南昌seo专业团队
  • 网站开发用笔记本电脑网站seo推广哪家值得信赖
  • c2c网站架构百度地图推广电话
  • 蚌埠公司做网站google推广工具
  • 旅游网站首页制作友链交换
  • php动态网站开发实例seo如何优化图片
  • 扬州网站建设培训淘宝推广软件
  • wordpress做登录百度seo怎么查排名