算法训练 审美课

时间限制:1.0s 内存限制:256.0MB

提交此题

问题描述

  《审美的历程》课上有n位学生,帅老师展示了m幅画,其中有些是梵高的作品,另外的都出自五岁小朋友之手。老师请同学们分辨哪些画的作者是梵高,但是老师自己并没有答案,因为这些画看上去都像是小朋友画的……老师只想知道,有多少对同学给出的答案完全相反,这样他就可以用这个数据去揭穿披着皇帝新衣的抽象艺术了(支持帅老师_)。

  答案完全相反是指对每一幅画的判断都相反。

输入格式

  第一行两个数n和m,表示学生数和图画数;

  接下来是一个n*m的01矩阵A:

  如果aij=0,表示学生i觉得第j幅画是小朋友画的;

  如果aij=1,表示学生i觉得第j幅画是梵高画的。

输出格式

  输出一个数ans:表示有多少对同学的答案完全相反。

样例输入

3 2

1 0

0 1

1 0

样例输出

2

样例说明

  同学1和同学2的答案完全相反;

  同学2和同学3的答案完全相反;

  所以答案是2。

数据规模和约定

  对于50%的数据:n<=1000;

  对于80%的数据:n<=10000;

  对于100%的数据:n<=50000,m<=20。




分析:0,1相反异或^即可。题目输入数据很大,需要用字符流来读写数据。不然会超时。

思路:用二进制表示每位同学的回答(状压)。(m<=20;2^20 在int的范围内)。相反的答案用二进制与m个1,1,1…1(即2^m-1)的数maxn取异或即可。(如 01 == 1 ,10 == 2,2^3 == 1(异或),1^3 == 2 )。



提高效率:map遍历可以取0~maxn/2即可。。设m个1,1,1…1(即2^m-1)的数为maxn,mid = maxn/2; 通过枚举你会发现 maxn^x = maxn-x = y (x,y属于[0,maxn]),(maxn与x逐位取异或 实际就是逐位做减法,因为maxn全为1(1>={0,1}),不存在减法借位),如(111-010 = 101 = 111^010),则[0,mid]的一个数x与maxn取异的值y一定在(mid,maxn]中。如(maxn = 7, 7^0=7 - 0 = 7、71=7-1=6、72=7-2=5).如果你遍历了map中的[0mid]那么后面的就不需要再遍历了,因为后面map中能与[0mid]匹配的值肯定已经被匹配过了。此步骤可要可不要,不会影响实际的通过。


Tips:这里使用了io流进行优化,看中细节的小伙伴可以看一看io软件包


---------------------

  1. import java.io.IOException;
  2. import java.io.InputStreamReader;
  3. import java.io.Reader;
  4. import java.util.HashMap;
  5. import java.util.Map.Entry;
  6. public class Main {
  7. private static Reader reader;
  8. public static void main(String[] args) {
  9. reader = new InputStreamReader(System.in);
  10. int n, m;
  11. n = getInt();
  12. m = getInt();
  13. HashMap<Integer, Integer> hm = new HashMap<>(n);
  14. for (int i = 0; i < n; ++i) {
  15. int num = 0, x = 0;
  16. for (int j = 0; j < m; j++) {
  17. x = getInt();
  18. num = (num << 1) + x;
  19. }
  20. hm.put(num, hm.containsKey(num) ? hm.get(num) + 1 : 1);
  21. }
  22. int sum = 0, maxn = (1 << m) - 1;
  23. for (Entry<Integer, Integer> entry : hm.entrySet()) {
  24. if (maxn / 2 < entry.getKey())
  25. continue;
  26. int key = entry.getKey() ^ maxn;
  27. if (hm.containsKey(key))
  28. sum += hm.get(key) * entry.getValue();
  29. }
  30. System.out.println(sum);
  31. }
  32. public static int getInt() {
  33. int res = 0, read;
  34. try {
  35. while ((read = reader.read()) != -1) {
  36. if (Character.isDigit(read)) {// 因为全是非负数,不需要判断负号‘-’,只要是数字就行
  37. res = read - '0';
  38. while ((read = reader.read()) != -1) {// 继续得到能得到的数字
  39. if (Character.isDigit(read)) {
  40. res = res * 10 + (read - '0');
  41. } else {
  42. break;
  43. }
  44. }
  45. break;
  46. }
  47. }
  48. } catch (IOException e) {
  49. // TODO Auto-generated catch block
  50. e.printStackTrace();
  51. }
  52. return res;
  53. }
  54. }

Java实现 蓝桥杯 算法训练 审美课的更多相关文章

  1. Java实现 蓝桥杯 算法训练 猴子吃包子(暴力)

    试题 算法训练 猴子吃包子 问题描述 从前,有一只吃包子很厉害的猴子,它可以吃无数个包子,但是,它吃不同的包子速度也不同:肉包每秒钟吃x个:韭菜包每秒钟吃y个:没有馅的包子每秒钟吃z个:现在有x1个肉 ...

  2. Java实现蓝桥杯 算法训练 大等于n的最小完全平方数

    试题 算法训练 大等于n的最小完全平方数 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 输出大等于n的最小的完全平方数. 若一个数能表示成某个自然数的平方的形式,则称这个数为完全平 ...

  3. java实现 蓝桥杯 算法训练 Password Suspects

    问题描述 在年轻的时候,我们故事中的英雄--国王 Copa--他的私人数据并不是完全安全地隐蔽.对他来说是,这不可接受的.因此,他发明了一种密码,好记又难以破解.后来,他才知道这种密码是一个长度为奇数 ...

  4. Java实现 蓝桥杯 算法训练VIP 报数(暴力+数学)约瑟夫环问题

    试题 算法训练 报数 问题描述 现有n个同学站成一圈,顺时针编号1至n.从1号同学开始顺时针1/2报数,报到1的同学留在原地,报到2的同学退出圆圈,直到只剩一名同学为止.问最后剩下的同学编号. 输入格 ...

  5. Java实现蓝桥杯 算法训练 ALGO-15 旅行家的预算

    问题描述 一个旅行家想驾驶汽车以最少的费用从一个城市到另一个城市(假设出发时油箱是空的).给定两个城市之间的距离D1.汽车油箱的容量C(以升为单位).每升汽油能行驶的距离D2.出发点每升汽油价格P和沿 ...

  6. Java实现 蓝桥杯 算法训练 多阶乘计算

    试题 算法训练 多阶乘计算 问题描述 我们知道,阶乘n!表示n*(n-1)(n-2)-21, 类似的,可以定义多阶乘计算,例如:5!!=531,依次可以有n!..!(k个'!',可以简单表示为n(k) ...

  7. Java实现 蓝桥杯 算法训练 找零钱

    试题 算法训练 找零钱 问题描述 有n个人正在饭堂排队买海北鸡饭.每份海北鸡饭要25元.奇怪的是,每个人手里只有一张钞票(每张钞票的面值为25.50.100元),而且饭堂阿姨一开始没有任何零钱.请问饭 ...

  8. Java实现 蓝桥杯 算法训练 第五次作业:字符串排序

    试题 算法训练 第五次作业:字符串排序 问题描述 输入一个小写字符串,按从小到大的顺序输出. 输入格式 bcaed 输出格式 abcde 顶格输出,中间没有空格 样例输入 一个满足题目要求的输入范例. ...

  9. Java实现 蓝桥杯 算法训练 求和求平均值

    试题 算法训练 求和求平均值 问题描述 从键盘输入10个浮点数,求出它们的和以及平均值,要求用函数实现 输入格式 测试数据的输入一定会满足的格式. 1 10 (1行10列的向量) 输出格式 要求用户的 ...

随机推荐

  1. NEON的比较是把所有的bit都设置为1

    NEON中的比较指令,如果结果为true,是把所有的bit都设置为1,而不是设置为1. ushort data1[4] = {129,0,136,255}; uint16x4_t v0 = vld1_ ...

  2. Spring Cloud 系列之 Config 配置中心(二)

    本篇文章为系列文章,未读第一集的同学请猛戳这里:Spring Cloud 系列之 Config 配置中心(一) 本篇文章讲解 Config 如何实现配置中心自动刷新. 配置中心自动刷新 点击链接观看: ...

  3. Luogu P5603 小C与桌游【贪心+拓扑排序】

    [Description]https://www.luogu.com.cn/problem/P5603 \(\;\) 题意可以简化为:一个不保证联通,n个点,m条边的DAG(有向无环图),构造一个拓扑 ...

  4. php_rce

    0x01 PHP_RCE RCE(remote command/code execute):远程命令/代码执行 此题为ThinkPHP V5远程代码执行漏洞 0x02 命令执行 http://124. ...

  5. 2018-06-19 js DOM对象

    DOM对象: Doucument Object Model即文档对象 DOM对象的操作: 1.找元素 返回元素对象: var obj=document.getElementById();//通过Id查 ...

  6. Python内置函数示例

    abs() 返回数字绝对值 >>> abs(-100) 100 >>> abs(10) 10 >>> all() 判断给定的可迭代参数 itera ...

  7. 2.1Go语言特性

    1.1.2. 编程语言类型 静态语言,动态语言 静态语言:强类型语言 ​ 定义变量,必须指明数据类型,存储对应类型的数据. ​ 例如java,go,c 动态语言:弱类型语言 ​ 定义变量,赋值过程决定 ...

  8. mysql小白系列_05 日常操作

    mysql启动/关闭 my.cnf的调用顺序 [root@docker02 bin]# ./mysql --help Default options are read from the followi ...

  9. java数值类型之间的转换

    说明:图中6个实心箭头代表转换无信息丢失,3个虚线箭头表示可能有精度损失的转换.

  10. ECharts使用教程

    引入 ECharts ECharts 3 开始不再强制使用 AMD 的方式按需引入,代码里也不再内置 AMD 加载器.因此引入方式简单了很多,只需要像普通的 JavaScript 库一样用 scrip ...