xdoj1001(又是苹果)

13 篇文章 0 订阅

本文代码转载自: http://www.cnblogs.com/zhurb/p/7253277.html,特别鸣谢~

1001: 又是苹果

时间限制: 1 Sec   内存限制: 128 MB
提交: 872   解决: 141
[ 提交][ 状态][ 讨论版]

题目描述

最近,亮亮和小W都对苹果很感兴趣!在研究了“最大苹果矩阵”和“给苹果树施肥”的问题后,他们又遇到了一个新的问题:

有一块长n米、宽m米的地,现在小W把地划分成边长1米的小正方形块,共n*m个块。每个块中可能种有一棵苹果树,或放有一个iPhone,也可以什么也没有。然而,亮亮拥有一种超能力,可以将2个宽1米、长度相同的矩形块在空间中直接交换。

亮亮经常对着农场施展超能力,为了不把自己搞晕,他每次总是选择两整行(长度均为m米)或两整列(长度均为n米)进行交换。小W对此十分恼火——当他想拿iPhone打游戏时,却莫名其妙地撞在了苹果树上。小W要求你写一个程序,帮助他确定某一正方形块中放了什么东西。

输入

输入包含多组数据,请处理到文件结束。
每组数据,第一行2个整数n、m,表示地的尺寸。
之后n行,每行m个英文字母,大写的T表示这里种有苹果树,小写的i表示这里放有iPhone,其他字符表示这里什么也没有。
之后1行,一个整数Q,表示小W询问的次数。
之后Q行,包含3个整数,可能有以下情况:
    1 i1 j1 表示小W想知道第i1行第j1列的方块中有什么东西。
    2 i1 i2 表示亮亮交换了第i1行与第i2行。
    3 j1 j2 表示亮亮交换了第j1列与第j2列。
对于100%的数据,有1<=n*m<=106,1<=Q<=105,1<=i1, i2<=n,1<=j1, j2<=m。

输出

对于每组数据,输出以一行“Case #x:”开头,x表示数据的编号,从1开始。
对于小W的每次格式为“1 i j”的询问,输出一行。若方块中是苹果树,输出"Tree"。若方块中是iPhone,输出“Phone”。若方块中什么也没有,输出“Empty”。

样例输入

2 2
Ti
Ti
2
1 1 1
1 2 2
3 3
Tct
Iai
qqT
3
1 1 3
2 1 2
1 1 3

样例输出

Case #1:
Tree
Phone
Case #2:
Empty
Phone


思路:直接开二维数组会TLE+MLE,这里介绍一种快速做法,将二维变一维,直接交换行号和列号,具体见代码(其实代码不是我写的~)
#include<bits/stdc++.h>
using namespace std;
int n,m,q,a[1000005],r[1000005],c[1000005];
string s;
int main()
{
    ios::sync_with_stdio(false);
    int z = 0;
    while(cin >> n >> m)
    {
        cout << "Case #" << ++z << ":" << endl;
        for(int i = 1;i <= n;i++)   r[i] = i;
        for(int i = 1;i <= m;i++)   c[i] = i;
        int cnt = 0;
        for(int i = 1;i <= n;i++)
        {
            cin >> s;
            for(int j = 0;j < m;j++)
            {
                if(s[j] == 'T') a[++cnt] = 1;
                else if(s[j] == 'i')    a[++cnt] = 2;
                else    a[++cnt] = 0;
            }
        }
        cin >> q;
        while(q--)
        {
            int x,y,z;
            cin >> x >> y >>z;
            if(x == 1)
            {
                int t = (r[y]-1)*m+c[z];
                switch(a[t])
                {
                    case 0: cout << "Empty" << endl;break;
                    case 1: cout << "Tree" << endl;break;
                    case 2: cout << "Phone" << endl;break;
                }
            }
            else if(x == 2) swap(r[y],r[z]);
            else swap(c[y],c[z]);
        }
    }

    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值