• 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

    持续更新中……

  • 相关阅读:
    AC自动机讲解超详细
    区间树Splay——[NOI2005]维护数列
    区间树Splay——[NOI2005]维护数列
    Trie学习总结
    微信小程序刮刮乐
    微信小程序获得高度
    微信小程序多video播放暂停问题
    vue中的问题思考
    vue的开发技巧
    微信小程序消息推送,前端操作
  • 原文地址:https://www.cnblogs.com/hfctf0210/p/15139214.html
Copyright © 2020-2023  润新知