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

企业微信官方网站如何制作视频网站

企业微信官方网站,如何制作视频网站,北京做网站报价,网站建设维护概括总结题目 输入一个整数数组,数组中只有一个数字出现了一次,而其他数字都出现了3次。请找出那个只出现一次的数字。例如,如果输入的数组为[0,1,0,1,0,1,100],则只…

题目

输入一个整数数组,数组中只有一个数字出现了一次,而其他数字都出现了3次。请找出那个只出现一次的数字。例如,如果输入的数组为[0,1,0,1,0,1,100],则只出现一次的数字是100。

分析

这个题目有一个简化版的类似的题目“输入数组中除一个数字只出现一次之外其他数字都出现两次,请找出只出现一次的数字”。任何一个数字异或它自己的结果都是0。如果将数组中所有数字进行异或运算,那么最终的结果就是那个只出现一次的数字。
在这个题目中只有一个数字出现了一次,其他数字出现了3次。相同的3个数字异或的结果是数字本身,但是将数组中所有数字进行异或运算并不能消除出现3次的数字。因此,需要想其他办法。
一个整数是由32个0或1组成的。我们可以将数组中所有数字的同一位置的数位相加。如果将出现3次的数字单独拿出来,那么这些出现了3次的数字的任意第i个数位之和都能被3整除。因此,如果数组中所有数字的第i个数位相加之和能被3整除,那么只出现一次的数字的第i个数位一定是0;如果数组中所有数字的第i个数位相加之和被3除余1,那么只出现一次的数字的第i个数位一定是1。这样只出现一次的任意第i个数位可以由数组中所有数字的第i个数位之和推算出来。当我们知道一个整数任意一位是0还是1之后,就可以知道它的数值。

public class Test {public static void main(String[] args) {int[] nums = {0, 1, 0, 1, 0, 1, 100};int result = singleNumber(nums);System.out.println(result);}public static int singleNumber(int[] nums) {int[] bitSums = new int[32];for (int num : nums) {for (int i = 0; i < 32; i++) {bitSums[i] += (num >> (31 - i)) & 1;}}int result = 0;for (int i = 0; i < 32; i++) {result = (result << 1) + bitSums[i] % 3;}return result;}
}
http://www.zhongyajixie.com/news/35312.html

相关文章:

  • 免费企业建站模板百度优化推广
  • 代办医疗网站域名备案管理课程培训
  • 个人店铺logo百度优化大师
  • 网站收藏的链接怎么做的百度权重1是什么意思
  • 郑州网站建设哪家公司好视频广告联盟平台
  • 不懂外贸做外贸网站好做吗网页搭建
  • 兖州网站建设多少钱温州seo服务
  • 东莞宣传网站最近大事件新闻
  • 免费做网站的站长统计网站统计
  • 娄底高端网站建设网络工程师是干什么的
  • 安徽省建设造价管理协会网站南京seo按天计费
  • iis的网站默认端口2022好用值得推荐的搜索引擎
  • wordpress修改导航栏广州优化公司哪家好
  • wordpress 免签约主题seo网站搭建是什么
  • 银川市做网站的公司网络优化培训
  • 射阳网站开发公司网站建设代理
  • 网站哪家做的比较好友情链接多少钱一个
  • 网站制作苏州优化营商环境心得体会
  • 怎么查什么时候做的网站北京seo招聘信息
  • 邯郸市网站建设百度关键词搜索排名多少钱
  • 专业做网站企业北京seo站内优化
  • 济南一哥网站建设公司百度推广入口
  • 网站网站开发免费创建网站的平台
  • 宁波seo深度优化平台有哪些seo网络培训班
  • 建网站做点什么好惠东seo公司
  • 怎么做中英文网站怎么制作网站教程步骤
  • 房地产网站加盟新浪微博指数查询
  • 武汉新天厦建设工程有限公司网站搜索引擎优化方法
  • 云平台网站叫什么北京seo编辑
  • 搜索关键词可以过得网站新乡百度关键词优化外包