1010: 四个年级

时间限制: 3 Sec  内存限制: 128 MB

题目描述

为了加强全体软件学院的同学的较量,学院想让ACM协会设计一次活动让所以软件学院的同学都加入,并且要实现高年级和低年级互动的效果。会长想了这样一个活动(可能有点无聊),他写了一个小程序,让每个年级的同学都来随机生成一个数字,如果有来着四个年级的四个同学他们手上的数字相加等于零,就称这是一组超强组合。例如一年级的同学的数字为{-45,-41,-36,26,32,1},二年级的同学数字为{22,-27,53,30,-38,-54},三年级的同学数字为{42,56,-37,-75,-10,-6},四年级同学数字为{-16,30,77,-46,62,45}。则有6组超强组合(-45,-27,42,30),(26,30,-10,-46),(-32,22,56,-46),(-32,30,-75,77),(-32,-54,56,30)(1 -27 42 -16)。你的任务是给你所有年级人的数字,让你计算有多少组超强组合。为了方便出来我们假设每个年级的人一样多。

输入

输入包含多组数据,第一行为测试数据T组(1<=T<=10);以下每组数据第一行包含一个数字N(1<=N<=2000)表示每个年级人数。接下来数N行,每行有4个数A1,A2,A3,A4(-1000<Ai<1000),分别表示一二三四年级同学的数字。

输出

输出超强组合的组数,没有就输出0。

样例输入

1
6
-45 22 42 -16
-41 -27 56 30
-36 53 -37 77
26 30 -75 -46
-32 -38 -10 62
1 -54 -6 45

样例输出

Case 1: 6

题目链接:https://acm.xju.edu.cn/JudgeOnline/problem.php?id=1010

这题就是要在每列找一个数,使4个数的和为0,问有几组这样的4个数。

直观的想法要4层循环,即4种数,所有情况都遍历一遍,这样肯定会超时。
因为时间复杂度是O(n^4),n = 2000。 所以我们优化一下,
map<int,int> m1,m2;
m1存前两种数的所有组合的和,m2存后两种数的所有组合的和。 然后遍历一遍就可以了。 代码:
#include <iostream>
#include <map>
using namespace std;
typedef long long ll; int a[][]; int main() {
int t,n;
cin >> t;
int k = ;
while(t--){
cin >> n;
for(int i = ;i < n; i++){
for(int j = ;j < ; j++){
cin >> a[i][j];
}
}
map <int,int> m1,m2;
for(int i = ;i < n; i++){
for(int j = ;j < n; j++){
m1[a[i][]+a[j][]]++;
m2[a[i][]+a[j][]]++;
}
}
int ans = ;
map <int,int>::iterator it;
for(it = m1.begin();it != m1.end(); it++){
ans += it->second*m2[-it->first];
}
cout << "Case " << ++k << ": ";
cout << ans << endl;
}
return ;
}
// writen by zhangjiuding
 

新疆大学(新大)OJ xju 1010: 四个年级 C++ STL map 将4层循环优化成2层循环可解的更多相关文章

  1. 各大Oj平台介绍 刷题平台

    https://leetcode.com/ http://www.cnblogs.com/lzmfywz/archive/2012/02/07/2342010.html 1.题库与网站资源题库-在线提 ...

  2. 各大Oj平台介绍

    1.题库与网站资源题库-在线提交系统(Online Judge)简介   下面是几个比较大的在线提交系统(OnlineJudge)里面有大量历年的竞赛题目,注册一个ID,然后用自己熟悉的语言(一般有P ...

  3. 宣化上人:大佛顶首楞严经四种清净明诲浅释(2-3) -------------------------------------------------------------------------------- (转自学佛网:http://www.xuefo.net/nr/article23/230612.html)

    大佛顶首楞严经四种清净明诲浅释(2-3) 唐天竺·沙门般剌密帝译 宣化上人主讲 一九八三年四月十七日晚讲于万佛圣城 欲摄其心入三摩地:这种邪师说法,在末法的时候像恒河沙这么多:可是我想在这时候,令一切 ...

  4. 蓝桥杯练习-各大OJ平台介绍

    校赛准备的不够充分,简单题失分太遗憾, 有幸参加到省赛,这次先码一下练习平台,等学期结束忙完之后好好练习! 1.题库与网站资源题库-在线提交系统(Online Judge)简介   下面是几个比较大的 ...

  5. 西南民大oj(两园交求面积)

    西南民大oj:http://www.swunacm.com/acmhome/welcome.do?method=index 我的几何不可能那么可爱 时间限制(普通/Java) : 1000 MS/ 3 ...

  6. CentOS6安装各种大数据软件 第四章:Hadoop分布式集群配置

    相关文章链接 CentOS6安装各种大数据软件 第一章:各个软件版本介绍 CentOS6安装各种大数据软件 第二章:Linux各个软件启动命令 CentOS6安装各种大数据软件 第三章:Linux基础 ...

  7. 宣化上人:大佛顶首楞严经四种清净明诲浅释(4-5)(转自学佛网:http://www.xuefo.net/nr/article23/230699.html)

    大佛顶首楞严经四种清净明诲浅释(4) 唐天竺·沙门般剌密帝译 宣化上人主讲 一九八三年四月十七日晚讲于万佛圣城 汝教世人修三摩地.先断心淫.是名如来.先佛世尊.第一决定清净明诲. 所以说,教人这个爱的 ...

  8. 宣化上人:大佛顶首楞严经四种清净明诲浅释(6-7)(转自学佛网:http://www.xuefo.net/nr/article23/230700.html)

    大佛顶首楞严经四种清净明诲浅释(6) 唐天竺·沙门般剌密帝译 宣化上人主讲 一九八三年四月十七日晚讲于万佛圣城 是故阿难!若不断杀修禅定者,譬如有人,自塞其耳,高声大叫,求人不闻,此等名为欲隐弥露.清 ...

  9. 宣化上人: 大佛顶首楞严经四种清净明诲浅释(8-9)(转自学佛网:http://www.xuefo.net/nr/article23/230825.html)

    大佛顶首楞严经四种清净明诲浅释(8) 唐天竺·沙门般剌密帝译 宣化上人主讲 一九八三年四月十七日晚讲于万佛圣城 各自谓己得上人法.詃惑无识.恐令失心.所过之处.其家耗散. 各自谓己:每一个都是自己称赞 ...

随机推荐

  1. ROS-SLAM仿真-cartographer

    前言:cartographer是谷歌2016年发布的一个开源slam算法,采用基于图网络的优化方法,主要基于激光雷达来实现. 使用源码编译方式. 一.新建工作空间 1.1 使用roboware新建名为 ...

  2. Centos7 minimal 系列之Redis共享sessionid(七)

    这一章节的内容就当看看,只是个人理解,我想应该是有误的. 一.SessionId sessionid是一个会话的key,浏览器第一次访问服务器会在服务器端生成一个session,有一个sessioni ...

  3. 浅谈SpringCloud (三) Ribbon负载均衡

    什么是负载均衡 当一台服务器的单位时间内的访问量越大时,服务器压力就越大,大到超过自身承受能力时,服务器就会崩溃.为了避免服务器崩溃,让用户有更好的体验,我们通过负载均衡的方式来分担服务器压力. 我们 ...

  4. javascript中缓存

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. Android 的永久登陆 与注销登陆

    一.永久登陆 sharedprefrence 存储 userID  以及 password private String FILE = "saveUserNamePwd";//用于 ...

  6. 「JavaSE 重新出发」05.01 继承

    继承 一个对象变量可以指示多种实际类型的现象被称为多态(polymorphism). 在运行时能够自动地选择调用哪个方法的现象称为动态绑定(dynamic binding). 如果是private方法 ...

  7. hdu 2795 Billboard 【线段树】

    给出一个高为h,宽为w的广告板,有n张广告需要贴,从第一行开始贴,尽量靠左,输出每个广告最后贴在哪一行的 先一直想不通这样建树是为什么 后来看到一篇题解里面的一句话“直到找到一个满足条件的叶子节点” ...

  8. CPU VS GPU

    CPU VS GPU 关于绘图和动画有两种处理的方式:CPU(中央处理器)和GPU(图形处理器).在现代iOS设备中,都有可以运行不同软件的可编程芯片,但是由于历史原因,我们可以说CPU所做的工作都在 ...

  9. Functional programming-函数式编程

    In computer science, functional programming is a programming paradigm—a style of building the struct ...

  10. CF1041F Ray in the tube构造_思维

    不难发现起点必定是一个点. 每次间隔的距离一定是 2k2^k2k,关键就是要判断两点是否在同一跳跃距离上可被同时覆盖. 我们可以对上边进行 x1≡x_{1}\equivx1​≡ x2mod(2∗dx) ...