题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4941

解题报告:给你一个n*m的矩阵,矩阵的一些方格中有水果,每个水果有一个能量值,现在有三种操作,第一种是行交换操作,就是把矩阵的两行进行交换,另一种是列交换操作,注意两种操作都要求行或列至少要有一个水果,第三种操作是查找,询问第A行B列的水果的能量值,如果查询的位置没有水果,则输出0.

因为n和m都很大,达到了2*10^9,但水果最多一共只有10^5个,我的做法是直接用结构体存了之后排序,然后map[i] = j,表示当前的i行相当于原地图中的j行,这样进行行交换操作的时候只要交换一下这个就可以了,原地图上的模样不变,列交换同理。

 #include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
#include<map>
using namespace std;
#define maxn 100005
struct node
{
int x,y,c;
}mat[maxn];
map<int,int> hang,lie;
bool cmp(node a,node b)
{
if(a.x == b.x) return a.y < b.y;
return a.x < b.x;
}
int query(int k,int x,int y)
{
int l = ,r = k,d = x,m;
while(l < r)
{
m = (l + r) >> ;
if(d <= mat[m].x) r = m;
else l = m + ;
}
int s1 = l;
if(mat[s1].x != x) return ; //没找到一个符合的x,说明没有这一行
l = ,r = k,d = x + ;
while(l < r)
{
m = (l + r) >> ;
if(d <= mat[m].x) r = m;
else l = m + ;
}
int s2 = l;
if(mat[s2].x != x) s2--;
l = s1,r = s2;
while(l < r)
{
m = (l + r) / ;
if(y <= mat[m].y) r = m;
else l = m + ;
}
if(mat[l].y != y) return ; //没找到符合的y,说明这一行的这一列没有
return mat[l].c;
}
int main()
{
int T,n,m,k,q,kase = ;
scanf("%d",&T);
while(T--)
{
scanf("%d%d%d",&n,&m,&k);
hang.clear();
lie.clear();
for(int i = ;i <= k;++i)
{
scanf("%d%d%d",&mat[i].x,&mat[i].y,&mat[i].c);
hang[mat[i].x] = mat[i].x;
lie[mat[i].y] = mat[i].y;
}
sort(mat+,mat+k+,cmp);
printf("Case #%d:\n",kase++);
scanf("%d",&q);
int op,a,b;
while(q--)
{
scanf("%d%d%d",&op,&a,&b);
if(op == )
{
swap(hang[a],hang[b]);
}
else if(op == )
{
swap(lie[a],lie[b]);
}
else if(op == )
{
a = hang[a];
b = lie[b];
printf("%d\n",query(k,a,b));
}
}
}
return ;
}
/*
5
4 4 4dlsdfflsfls
1 1 1
2 4 4
3 2 2
4 4 3
*/

再附上一种短代码的完全用map实现的,其实关键就是用pair<int,int>作为键。

 #include<cstdio>
#include<map>
#include<iostream>
#include<algorithm>
using namespace std;
int T,n,m,k,x,y,c,q,kase;
map<int,int> hang,lie;
map<pair<int,int>,int> mp;
int main()
{
scanf("%d",&T);
kase = ;
while(T--)
{
scanf("%d%d%d",&n,&m,&k);
hang.clear(),lie.clear(),mp.clear();
while(k--)
{
scanf("%d%d%d",&x,&y,&c);
hang[x] = x,lie[y] = y;
mp[pair<int,int> (x,y)] = c;
}
printf("Case #%d:\n",kase++);
scanf("%d",&q);
while(q--)
{
scanf("%d%d%d",&c,&x,&y);
if(c == ) swap(hang[x],hang[y]);
else if(c == ) swap(lie[x],lie[y]);
else
{
x = hang[x],y = lie[y];
printf("%d\n",mp[pair<int,int> (x,y)]);
}
}
}
return ;
}

HDU 4941 Magical Forest(map映射+二分查找)杭电多校训练赛第七场1007的更多相关文章

  1. HDU 4902 Nice boat 2014杭电多校训练赛第四场F题(线段树区间更新)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4902 解题报告:输入一个序列,然后有q次操作,操作有两种,第一种是把区间 (l,r) 变成x,第二种是 ...

  2. HDU 4864 Task (贪心+STL多集(二分)+邻接表存储)(杭电多校训练赛第一场1004)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4864 解题报告:有n台机器用来完成m个任务,每个任务有一个难度值和一个需要完成的时间,每台机器有一个可 ...

  3. hdu 4941 Magical Forest

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=4941 Magical Forest Description There is a forest can ...

  4. hdu 4941 Magical Forest (map容器)

    Magical Forest Time Limit: 24000/12000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Other ...

  5. STL : map函数的运用 --- hdu 4941 : Magical Forest

    Magical Forest Time Limit: 24000/12000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Other ...

  6. hdu 4941 Magical Forest ( 双重map )

    题目链接 题意: 有一个n*m的田地,里边有k棵树,每棵树的位置为(xi,yi),含有能量值ci.之后又q个询问,分三种; 1)1 a b,将a行和b行交换 2)2 a b,将a列和b列交换 3)3 ...

  7. HDU 5371 (2015多校联合训练赛第七场1003)Hotaru&#39;s problem(manacher+二分/枚举)

    pid=5371">HDU 5371 题意: 定义一个序列为N序列:这个序列按分作三部分,第一部分与第三部分同样,第一部分与第二部分对称. 如今给你一个长为n(n<10^5)的序 ...

  8. HDU 4941 Magical Forest 【离散化】【map】

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4941 题目大意:给你10^5个点.每一个点有一个数值.点的xy坐标是0~10^9.点存在于矩阵中.然后 ...

  9. HDU 4941 Magical Forest --STL Map应用

    题意: 有n*m个格子(n,m <= 2*10^9),有k(k<=10^5)个格子中有值,现在有三种操作,第一种为交换两行,第二种为交换两列,交换时只有两行或两列都有格子有值或都没有格子有 ...

随机推荐

  1. Yocto开发笔记之《嵌入式linux libcurl编程》(QQ交流群:519230208)

    开了一个交流群,欢迎爱好者和开发者一起交流,转载请注明出处. QQ群:519230208,为避免广告骚扰,申请时请注明 “开发者” 字样 =============================== ...

  2. 阿里巴巴集团2016校园招聘-Python工程师笔试题(附加题+部分答案)

    前言 第一次网上笔试,被虐的很惨.一是不太习惯,最主要的是还是自己对Python的掌握,还不够熟练.下面是这次阿里笔试相关信息 笔试时间是,2015年8月23日,10:00——12:00 对于笔试题, ...

  3. MongoDB的安装及CURD操作

    MongoDB的下载地址:http://www.mongodb.org/downloads MongoDB有32bit和64bit两个版本,32bit只能存放2GB数据.我们选择64bit版进行下载. ...

  4. js011-DOM扩展

    js011-DOM扩展 本章内容 理解Selecters API 使用HTML5 DOM扩展 了解转悠的DOM扩展 11.1选择符API JS中最常用的一项功能,就是根据css选择符选择与某个模式匹配 ...

  5. 转: CvMat,Mat和IplImage之间的转化和拷贝

    1.CvMat之间的复制 //注意:深拷贝 - 单独分配空间,两者相互独立 CvMat* a; CvMat* b = cvCloneMat(a); //copy a to b 2.Mat之间的复制 / ...

  6. parted命令详解

    parted命令详解   用法:parted [选项]... [设备 [命令 [参数]...]...]   将带有“参数”的命令应用于“设备”.如果没有给出“命令”,则以交互模式运行.   帮助选项: ...

  7. js数字、字符串、数组之间的转化

    1.数组转字符串 var a, b; a = ,,,,); b = a.join("-"); 2.字符串转数组 var s = "abc,abcd,aaa"; ...

  8. Ftp软件

    http://www.xlightftpd.com/cn/index.htm FileZilla Server官网:http://www.filezilla-project.org/

  9. ssh远程连接ubuntu

    1. 首先在服务器上安装ssh的服务器端. $ sudo aptitude install openssh-server 2. 启动ssh-server. $  sudo /etc/init.d/ss ...

  10. C# 正则分组捕获

    分组语法 捕获 (exp) 匹配exp,并捕获文本到自动命名的组里 (?<name>exp) 匹配exp,并捕获文本到名称为name的组里,也可以写成(?'name'exp) (?:exp ...