zoukankan      html  css  js  c++  java
  • 2021杭电多校第七场题解

    H

    读错题导致卡了2h,然后才发现走的路径是固定的。

    于是这就是签到题

    #include<bits/stdc++.h>
    using namespace std;
    int n,x,y,d,tx[4]={0,1,0,-1},ty[4]={1,0,-1,0},dc[4]={1,2,3,0},du[4]={3,0,1,2};
    int main()
    {
        int T;scanf("%d",&T);
        while(T--)
        {
            scanf("%d%d%d",&x,&y,&d);
            scanf("%d",&n);
            while(n--)
            {
                int nx,ny,dx,dy;scanf("%d%d",&nx,&ny);
                dx=nx-x,dy=ny-y;
                if(tx[d])
                {
                    if(dx/tx[d]>=0)
                    {
                        for(int i=1;i<=abs(dx);i++)printf("f");
                        if(dy)
                        {
                            if(dy/ty[dc[d]]>0)d=dc[d],printf("c");
                            else d=du[d],printf("u");
                            for(int i=1;i<=abs(dy);i++)printf("f");
                        }
                    }
                    else{
                        if(dy/ty[dc[d]]>0)d=dc[d],printf("c");
                        else d=du[d],printf("u");
                        for(int i=1;i<=abs(dy);i++)printf("f");
                        if(dx/tx[dc[d]]>0)d=dc[d],printf("c");
                        else d=du[d],printf("u");
                        for(int i=1;i<=abs(dx);i++)printf("f");
                    }
                }
                else if(dy/ty[d]>=0)
                {
                    for(int i=1;i<=abs(dy);i++)printf("f");
                    if(dx)
                    {
                        if(dx/tx[dc[d]]>0)d=dc[d],printf("c");
                        else d=du[d],printf("u");
                        for(int i=1;i<=abs(dx);i++)printf("f");
                    }
                }
                else{
                    if(dx/tx[dc[d]]>0)d=dc[d],printf("c");
                    else d=du[d],printf("u");
                    for(int i=1;i<=abs(dx);i++)printf("f");
                    if(dy/ty[dc[d]]>0)d=dc[d],printf("c");
                    else d=du[d],printf("u");
                    for(int i=1;i<=abs(dy);i++)printf("f");
                }
                x=nx,y=ny;
            }
            puts("");
        }
    }
    View Code

    J

    持续更新中……

  • 相关阅读:
    修改Ubuntu从文本界面登录
    Putty等工具中解决SSH连接超时断开的问题
    QoS policy-map class-map
    Linux中的do{...} while(0)
    手动增加swap分区
    __attribute__ 机制详解(一)
    欢迎来语雀关注我
    WebForm 生成并显示二维码
    《C#图解教程》 总览
    C#图解教程 第二十五章 其他主题
  • 原文地址:https://www.cnblogs.com/hfctf0210/p/15139214.html
Copyright © 2011-2022 走看看