http://nanti.jisuanke.com/t/15

题目要求是求出只出现一次的数字,其余数字均出现三次。

之前有过一个题是其余数字出现两次,那么就是全部亦或起来就得到答案。

这题有些不太一样。

显然,最裸的做法就是cnt[i]表示i出现的次数。然后求出cnt[i]为1的那一个。

然后可能会考虑到,对于这些数字的二进制位来看,某一位二进制位出现3的倍数次的话,那么只出现一次的数字这一位一定是0。如果出现3的倍数加1次,那么自然,只出现一次的数字这一位一定是1。

然后就考虑用cnt[i]表示,这些数二进制第i位,出现1的次数。

最后答案就能用cnt[32]生成了。

时间复杂度O(nlogx),空间32*int。

其实我们考虑的时候,只需要保存cnt[i]%3的结果,也就是说cnt[i]的取指只有0,1,2三种。

那么我们就可以这样来设定状态,cnt[i]表示:当cnt[i]的某位二进制位出现1时,表示这些数字在这一位出现的次数模3是i。

于是就有cnt[1], cnt[2], cnt[3]三种了,而且这三个二进制位的某一个只有一个是1。

接下来考虑状态是怎么转移的。

加入新加入一个x。

这个x的第j位是1。

那么如果cnt[i-1]的第j位是1,cnt[i]的第j位就将要变成1。这是出现进位的情况。

那么如果cnt[i]的第j为是0,自然,除非发生进位,否则还是0。

如果x的第j位是0。

那么如果cnt[i]的第j位是1,那么还是1。

那么如果cnt[i]的第j为是0,那么还是0。

也就是说,新的cnt[i]将有两部分构成,一部分是原有的1,而且没有进位的,还有一部分是进位得到的1。

对于原有没有进位的1,满足原0,现在还是0;原1,来了1,变成0;原1,来了0,还是1;发现~x&cnt[i]满足这个条件。

对于进位得到的1,显然是x&cnt[i-1]。

两部分结合cnt[i] = (x&cnt[i-1])&(~x&cnt[i])。

于是可以时间复杂度O(n)实现。

代码:

#include <iostream>
#include <cstdio>
#include <cstdlib> using namespace std; int main()
{
int n, x, y, z, t, a;
while (scanf("%d", &n) != EOF)
{
x = y = ;
z = ~;
for (int i = ; i < n; ++i)
{
scanf("%d", &a);
t = (a&x)|(~a&y);
x = (a&z)|(~a&x);
z = (a&y)|(~a&z);
y = t;
}
printf("%d\n", x);
}
}

ACM学习历程—计蒜客15 单独的数字(位运算)的更多相关文章

  1. 爬虫acm比赛成绩(多页成绩整合在一起、获取复制不了的数据)(hihocoder、计蒜客)

    https://github.com/congmingyige/web-crawler_rank-of-competition-in-JiSuanKe-and-hihocoder 1. 计蒜客(获取复 ...

  2. 计蒜客 28449.算个欧拉函数给大家助助兴-大数的因子个数 (HDU5649.DZY Loves Sorting) ( ACM训练联盟周赛 G)

    ACM训练联盟周赛 这一场有几个数据结构的题,但是自己太菜,不会树套树,带插入的区间第K小-替罪羊套函数式线段树, 先立个flag,BZOJ3065: 带插入区间K小值 计蒜客 Zeratul与Xor ...

  3. 计蒜客的一道题dfs

    这是我无聊时在计蒜客发现的一道题. 题意: 蒜头君有一天闲来无事和小萌一起玩游戏,游戏的内容是这样的:他们不知道从哪里找到了N根不同长度的木棍, 看谁能猜出这些木棍一共能拼出多少个不同的不等边三角形. ...

  4. 计蒜客 31436 - 提高水平 - [状压DP]

    题目链接:https://nanti.jisuanke.com/t/31436 作为一名车手,为了提高自身的姿势水平,平时的练习是必不可少的.小 J 每天的训练包含 $N$ 个训练项目,他会按照某个顺 ...

  5. 2019icpc徐州站 Cat 计蒜客 - 42540 && The Answer to the Ultimate Question of Life, The Universe, and Everything. 计蒜客 - 42545

    VJ链接:https://vjudge.net/contest/412095#problem/A Cat 计蒜客 - 42540 题意: 给你一个区间[L,R],给你现在拥有的钱S.你需要从[L,R] ...

  6. 计蒜客 作弊揭发者(string的应用)

    鉴于我市拥堵的交通状况,市政交管部门经过听证决定在道路两侧安置自动停车收费系统.当车辆驶入车位,系统会通过配有的摄像头拍摄车辆画面,通过识别车牌上的数字.字母序列识别车牌,通过连接车管所车辆信息数据库 ...

  7. 计蒜客模拟赛5 D2T1 成绩统计

    又到了一年一度的新生入学季了,清华和北大的计算机系同学都参加了同一场开学考试(因为两校兄弟情谊深厚嘛,来一场联考还是很正常的). 不幸的是,正当老师要统计大家的成绩时,世界上的所有计算机全部瘫痪了. ...

  8. 计蒜客 等边三角形 dfs

    题目: https://www.jisuanke.com/course/2291/182238 思路: 1.dfs(int a,int b,int c,int index)//a,b,c三条边的边长, ...

  9. 计蒜客 方程的解数 dfs

    题目: https://www.jisuanke.com/course/2291/182237 思路: 来自:https://blog.csdn.net/qq_29980371/article/det ...

随机推荐

  1. Ubuntu 14.04上架IPSec+L2TP的方法

    最简单的方法是使用脚本一步一步地进行配置.我用的是philplckthun写的脚本,修改了一下获取服务器IP的方法:脚本文件. 在ubuntu下运行: sh setup.sh 配置配置完成后,服务器端 ...

  2. [CF489D]Unbearable Controversy of Being

    题目大意:求有向图中这种图的数量 从分层图来考虑,这是一个层数为3的图 枚举第一个点能到达的所有点,对他们进行BFS求第三层的点(假装它是BFS其实直接枚举效果一样) 代码: #include< ...

  3. 初识 Zookeeper

    云计算越来越流行的今天,单一机器处理能力已经不能满足我们的需求,不得不采用大量的服务集群.服务集群对外提供服务的过程中,有很多的配置需要随时更新,服务间需要协调工作,这些信息如何推送到各个节点?并且保 ...

  4. Can't bind multiple parameters ('header' and 'parameters') to the request's content.

    2019-01-23 15:46:29.012+08:00 ERROR [6]: System.InvalidOperationException: Can't bind multiple param ...

  5. C-RAN

    无线接入网(RAN)是移动运营商赖以生存的重要资产.传统的无线接入网具有以下特点: 1. 每一个基站连接若干个固定数量的扇区天线,并覆盖小片区域,每个基站只能处理本小区收发信号: 2. 系统的容量是干 ...

  6. java-四则运算-四

    题目要求:查找数组连成环形的和最大的连续子数组 实验代码: package zuoYe; import java.util.Scanner; public class MaxSubArray { pu ...

  7. thinkphp接收阿里淘宝客数据

    坑在于淘宝客api返回的数据对象是SimpleXMLElement Object类型,不转为php的json array类型数据直接扔到thinkphp循环输出中会达不到要的效果,奇奇怪怪的数组,一度 ...

  8. 【Demo】CSS3 2D转换

    2D转换transform 2D变换方法: translate() 根据左(X轴)和顶部(Y轴)位置给定的参数,从当前元素位置移动. div { transform: translate(50px,1 ...

  9. 关于Java类

    一个.java文件中可以有很多类.不过注意以下几点: 1.public 权限的类只能有一个(也可以一个都没有,但最多只有1个) 2.这个.java文件的文件名必须是public类的类名(一般的情况下, ...

  10. 双系统在Linux下查看win的硬盘(Ubuntu 16.04 挂载Windows的 硬盘)

    一般情况下,Linux的桌面系统能够直接查看到计算机各个硬盘的文件情况 但是,当我们想通过命令行查看Windows下的硬盘的时候,会发现在 /media/ (一般Windows下的盘会挂载到这里)文件 ...