[ACM] 1007 -球球方格

本文介绍了一个迷宫路径模拟算法,该算法通过控制角色在固定的迷宫中按特定规则移动,来模拟不同时间点角色的位置变化。角色可以在迷宫中沿着边界来回移动,每秒移动一格,最终输出经过指定时间后的具体位置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

与兔子方格类似,不过一秒走一格;

 输入

5
6 5 2 0 10
10 10 4 4 6
3 20 0 0 7
30 30 2 28 4
3 3 1 0 100
View Code

 

代码

#include<iostream>
using namespace std;

int main(void) {
    int test_count;
    freopen("input.txt", "r", stdin);
    cin >> test_count;

    
    int R;//行数
    int C;//列数
    int A, B;//出发点坐标    
    int N;//经过时间
    int flagA;
    int flagB;
    for (int test_case = 1; test_case <= test_count; test_case++)
    {
        cin >> R >> C >> A >> B >> N;
        flagA = 1;//默认开始每个例子都是向右下角移动
        flagB = 1;

        while (N>0)
        {
            if (A != R - 1) {
                if(flagA == 1)
                {
                    A++;
                    if (A == R - 1)
                    {
                        flagA = -1;
                        
                    }
                    else
                    {
                        flagA = 1;
                        
                    }
                }
                else
                {
                    A--;
                    if (A == 0) {
                        flagA = 1;
                        
                    }
                    else
                    {
                        flagA = -1;
                        
                    }
                }
                
                
            }
            
            else 
            {
                if (flagA == -1)
                {
                    A--;
                    if (A == 0) {
                        flagA = 1;
                        
                    }
                    else
                    {
                        flagA = -1;
                        
                    }
                }
                else
                {
                    A++;
                    if (A == R - 1) {
                        flagA = -1;                        
                    }
                    else
                    {
                        flagA = 1;
                        
                    }
                }                
                
            }

            if (B != C - 1) {
                if (flagB == 1)
                {
                    B++;
                    if (B == C - 1)
                    {
                        flagB = -1;

                    }
                    else
                    {
                        flagB = 1;

                    }
                }
                else
                {
                    B--;
                    if (B == 0) {
                        flagB = 1;

                    }
                    else
                    {
                        flagB = -1;

                    }
                }


            }

            else
            {
                if (flagB == -1)
                {
                    B--;
                    if (B == 0) {
                        flagB = 1;

                    }
                    else
                    {
                        flagB = -1;

                    }
                }
                else
                {
                    B++;
                    if (B == C - 1) {
                        flagB = -1;

                    }
                    else
                    {
                        flagB = 1;

                    }
                }

            }
            N--;
        }


        cout << "#" << test_case << " " << A << " " << B << endl;
    }

    return 0;
}
View Code

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值