算法训练 审美课

时间限制: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. 一阶RC低通滤波器详解(仿真+matlab+C语言实现)

    文章目录 1 预备知识 2 simulink 仿真 3 simulink 运行结果 4 matlab实现 5 matlab运行结果 6 C语言实现 7 C语言运行结果 如果本文帮到了你,帮忙点个赞: ...

  2. docker redis shell

    docker中安装好redis后,运行 docker ps 指令,查看所有运行中的镜像信息 然后运行 docker inspect --format "{{ .State.Pid}}&quo ...

  3. Cassandra数据建模

    1.  概述 Apache Cassandra将数据存储在表中,每个表都由行和列组成.CQL(Cassandra查询语言)用于查询存储在表中的数据.Apache Cassandra数据模型基于查询并针 ...

  4. 聊聊 TypeScript 中的类型保护

    聊聊 TypeScript 中的类型保护 在 TypeScript 中使用联合类型时,往往会碰到这种尴尬的情况: interface Bird { // 独有方法 fly(); // 共有方法 lay ...

  5. springData表关系:一对多

    一.编写实体类进行表关联 1.在一张表的关联属性上添加@OneToMany注解(关联属性用来记录多的一方的信息,是个集合,一般用set) 2.在另一个实体类的关联属性上添加@ManyToOne注解和  ...

  6. docker部署微服务遇到的问题二

    自己尝试将微服务部署到docker上面,期间按照周立的微服务架构实战13章进行学习 按照书上的步骤,一切部署成功之后,尝试访问,一直没有成功访问,周五部署了两遍 折腾了一下 还是没有找到为啥,周一继续 ...

  7. JSP+Servlet+JDBC+mysql实现的学生成绩管理系统

    项目简介 项目来源于:https://gitee.com/zzdoreen/SSMS 本系统基于JSP+Servlet+Mysql 一个基于JSP+Servlet+Jdbc的学生成绩管理系统.涉及技术 ...

  8. 小程序-云开发 bindscroll滚动事件执行setData()方法,导致scroll-view视图抖动

    需求描述 想做一个类似京东小程序首页功能列表左右滑动的效果,效果图如下 遇到的问题 1. 如何让scroll-view显示两行 做过小程序开发的都知道,scroll-view要么显示一行,可以左右滚动 ...

  9. c#word文档输出

    在工作中有时需要把内容用word文档展示出来 在写代码前要引用word的dll Microsoft.Office.Interop.Word“ sing System; using System.Col ...

  10. React:Element

    React Elements 是构成React App的最小单位.React中的组件是由一个或多个Elements构成的. 和DOM不同,React Elements 是纯粹的JS对象.利用React ...