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

云浮网站建设公司怎么建公众号申请

云浮网站建设公司,怎么建公众号申请,欧莱雅官方网站的建设,男女做的那些事情的网站在一个数组中仅出现一次,其他数均出现两次,这个出现一次的数就被称为“单身狗“。 一.一个单身狗 我们知道异或运算操作符 ^ ,它的特点是对应二进制位相同为 0,相异为 1。 由此我们容易知道两个相同的数,进行异或运算得到的结果…

在一个数组中仅出现一次,其他数均出现两次,这个出现一次的数就被称为“单身狗“。

一.一个单身狗

我们知道异或运算操作符 ^ ,它的特点是对应二进制位相同为 0,相异为 1

由此我们容易知道两个相同的数,进行异或运算得到的结果一定为 0,0和非0数字异或的结果为非0数字,因此我们可以将数组中的所有元素都进行异或,出现过两次的数异或结果将为0,留下来的就是单身狗了。

代码实现:

int FindSingle(int* arr,int sz)
{int dog = 0;int i = 0;for (i = 0; i < sz; i++){dog ^= arr[i];}return dog;
}
int main()
{int arr[5] = { 1,4,2,1,2 };int sz = sizeof(arr) / sizeof(arr[0]);printf("单身狗为:%d\n", FindSingle(arr, sz));return 0;
}

二.两个单身狗

如果数列中存在两个单身狗,依然和上面一样全部进行异或运算显然是得不到答案的,相同的数通过异或消除了,得到的会是两个单身狗异或的结果。

能不能将两个单身狗分开,在两个数组中分别以上面的方式找出单身狗呢?

异或的条件是对应二进制位相同为 0,相异为 1。通过两个单身狗数异或的结果,我们可以得到两个单身狗数在某些二进制位上单身狗的值不同(0或1),可以通过这位上的值不同来将两个单身狗分开。

同样,对于出现过两次的非单身狗数,也可以通过判断某一二进制位相同,将其放入同一数组中,再对该数组进行异或运算后消除。

代码实现:

void FindSingle(int* arr, int sz,int* dog,int* dog1,int* dog2)
{int i = 0;for (i = 0; i < sz; i++){//全部异或得到两个单身狗的异或结果*dog ^= arr[i];}//两个单身狗数某二进制位上的值不同int pos = 0;for (i = 0; i < 4; i++){//dog的值为两个单身狗数异或的结果,dog的某一二进制位为1则代表两个单身狗在这一二进制位上不相等//找出这一位置并拷贝下来if (((*dog >> i) & 1) == 1){pos = i;break;}}//将数组按pos位上的值为1或0分组并求异或for (i = 0; i < sz; i++){if (((arr[i] >> pos) & 1) == 1){*dog1 ^= arr[i];}else{*dog2 ^= arr[i];}}
}
int main()
{int arr[10] = { 1,2,3,4,5,1,2,3,4,6 };int dog = 0;int dog1 = 0;int dog2 = 0;int sz = sizeof(arr) / sizeof(arr[0]);FindSingle(arr, sz, &dog, &dog1, &dog2);printf("单身狗1是:%d,单身狗2是:%d", dog1, dog2);return 0;
}

http://www.yayakq.cn/news/948976/

相关文章:

  • 网站分页用什么设置京紫元年深圳网站建设
  • 医院营销型网站建设做外贸常用的网站有哪些
  • 网站建设演讲稿黄山网站开发
  • 技术支持海安网站建设受欢迎的句容网站建设
  • 北京 好的网站制作龙岗建设网站公司
  • 网站建设公司加盟个人博客网页制作图片
  • 上海创新网站建设网站关键词排名全掉了
  • 魔兽7.2国内做插件网站网站建设犭金手指a15
  • 温州网站建设专家pc网站建设怎么样
  • 搜索引擎优化seo网站曹鹏的wordpress教程
  • 网站建设四川网站续费服务内容
  • 湖南做网站的公司注册平台
  • 做的网站打开显示无标题池州最好的网站建设
  • 论坛网站建设价格网络营销策划包括哪些内容
  • 陵水网站建设哪家好郑州优化网站关键词
  • 福州专业网站设计公司福州外文网站建设
  • 注册网站多少钱星锐网站建设
  • 安阳网站建设哪家便宜青岛房产网官网
  • 请人做网站需要问哪些问题中国建设银行官方网站纪念币预约
  • 如何做pc网站适配网站开发包含的项目和分工
  • 网架公司安全员需要什么证书网站优化检测工具
  • 金融网站 源码怎样做服装网站
  • 免费个人网站模版下载四川建设学网官方网站登录
  • wordpress 设置固定链接seo短视频网页入口营销策略
  • 做网站多h5应用
  • 建设厅网站业务系统板块查成绩中国建设网官方网站平台
  • 企业网站怎么管理系统型网站建设
  • 成都建设银行保安招聘网站阜阳做网站
  • 国内优秀的响应式网站网站二级页面设计
  • 亿唐网不做网站做品牌怎么可以创建网站