搞死人的题目,,,

就是在n*n的方格中找路径长度为L的回路。

开始的思路值适合n为偶数的情况,而忽视了奇数的case,所以wa了一次。

然后找奇数case的策略,代码从70多行变成了100多,然后改了又改,自己在下面测了好久,交上去1y,但心里却无成就感。

这样的一个题目,提不上什么思路,可以算作是乱搞的,下次比赛中再次碰到类似甚至同样的题目,我并不能保证能写出来。

代码如下:

#include <cstdio>
#include <cstring>
#include <cmath>
#include <cstdlib>
#include <queue>
#include <stack>
#include <map>
#include <vector>
#include <algorithm> #define M 1005 using namespace std; int n, l, maxx; int main ()
{
scanf("%d%d",&n, &l);
if(l&1||n*n<l) printf("Unsuitable device\n");
else
{
printf("Overwhelming power of magic\n");
int c = l/(2*n);
int last = l%(2*n);
printf("1 1\n");
if(l<2*n)
{
int m = last/2;
for(int i = 2; i <= m; ++i)
printf("%d %d\n",2*c+1,i);
for(int i = m; i >= 2; --i)
printf("%d %d\n",2*c+2,i);
printf("2 1\n");
}
else if(n&1)
{
maxx = 2*c;
if(last==0)
{
for(int i = 1; i <= 2*c; ++i)
{
if(i&1)
for(int j = 2; j <= n; ++j)
printf("%d %d\n",i,j);
else
for(int j = n; j >= 2; --j)
printf("%d %d\n",i,j);
}
}
else
{
for(int i = 1; i < 2*c; ++i)
{
if(i&1)
for(int j = 2; j <= n; ++j)
printf("%d %d\n",i,j);
else
for(int j = n; j >= 2; --j)
printf("%d %d\n",i,j);
}
int nn = n-2*c;
int cc = last/(2*nn);
int ll = last%(2*nn);
int mm = n-2*cc;
for(int i = n; i > n-2*cc; --i)
{
if(i&1)
for(int j = 2*c; j <= n; ++j)
printf("%d %d\n",j,i);
else
for(int j = n; j >= 2*c; --j)
printf("%d %d\n",j,i);
}
if(ll==0)
{
for(int i = mm; i >= 2; --i)
printf("%d %d\n",2*c,i);
}
else
{
int tm = ll/2;
for(int i = 2*c; i <= 2*c+tm; ++i)
printf("%d %d\n",i,mm);
for(int i = 2*c+tm; i >= 2*c; --i)
printf("%d %d\n",i,mm-1);
mm-=2;
for(int i = mm; i >= 2; --i)
printf("%d %d\n",2*c,i);
}
}
for(int i = maxx; i >= 2; --i)
printf("%d 1\n",i);
}
else
{
for(int i = 1; i <= 2*c; ++i)
{
if(i&1)
for(int j = 2; j <= n; ++j)
printf("%d %d\n",i,j);
else
for(int j = n; j >= 2; --j)
printf("%d %d\n",i,j);
}
if(last == 0)
maxx = 2*c;
else if(last == 2)
{
printf("%d %d\n",2*c+1,2);
maxx = 2*c+1;
}
else
{
int m = last/2;
maxx = 2*c+2;
for(int i = 2; i <= m; ++i)
printf("%d %d\n",2*c+1,i);
for(int i = m; i >= 2; --i)
printf("%d %d\n",2*c+2,i);
}
for(int i = maxx; i >= 2; --i)
printf("%d 1\n",i);
}
}
return 0;
}

URAL - 1920 Titan Ruins: the Infinite Power of Magic(乱搞)的更多相关文章

  1. URAL 1920 Titan Ruins: the Infinite Power of Magic

    大意: 有一张N*N的网格,你每次可以走一步,每格只能走一次,有没有一种方法让走了L步后回到一个距原点1步远的格子?  没有输出Unsuitable device,否则输出Overwhelming p ...

  2. URAL - 1917 Titan Ruins: Deadly Accuracy(水题)

    水题一个,代码挫了一下: 题意不好理解. 你去一个洞窟内探险,洞窟内有许多宝石,但都有魔法守护,你需要用魔法将它们打下来. 每个宝石都有自己的防御等级,当你的魔法超过它的防御等级时它就会被你打下来. ...

  3. URAL 1915 Titan Ruins: Reconstruction of Bygones(思路)

    搞这个题差不多是从比赛开始到结束. 从自信慢慢的看题一直到wrong到死. 这个题目可以说成是思路题,以为我们只要明白一点,这道题就成了纯暴力的水题, 那就是当操作数不足栈中数字数目的时候,我们就没有 ...

  4. 【URAL 1917】Titan Ruins: Deadly Accuracy(DP)

    题目 #include<cstdio> #include<algorithm> using namespace std; #define N 1005 int n, m, cn ...

  5. URAL 1827 Indigenous Wars(排序、乱搞)

    题意:给一个长度为n数组{a[i]}.有m个操作Ti,Si,Li表示找以Ti值结束,以Si值开始,长度为Li的连续子串.找到后,将区间的答案值设为1.一开始答案值全部为0.最后输出n个答案值. 好久没 ...

  6. Ural 1780 Gray Code 乱搞暴力

    原题链接:http://acm.timus.ru/problem.aspx?space=1&num=1780 1780. Gray Code Time limit: 0.5 secondMem ...

  7. [USACO2002][poj1945]Power Hungry Cows(启发式搜索)

    Power Hungry CowsTime Limit: 1000MS Memory Limit: 30000K Total Submissions: 4570 Accepted: 1120 Desc ...

  8. 2016中国大学生程序设计竞赛 网络选拔赛 I This world need more Zhu

    This world need more Zhu Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  9. OrientDB入门(1)Getting Started

    Running OrientDB the First Time First, download and extract OrientDB by selecting the appropriate pa ...

随机推荐

  1. 在php中写接口时 对json格式的转换 简单的方法

    方法 一 方法二 可以通过urlencode();遍历出来

  2. Android开发--微信布局(ListView)基本运用

    ListView 1.ListVeiw 用来展示列表的View. 2.适配器 用来把数据映射到ListView上的中介. 3.数据    具体的将被映射的字符串,图片,或者基本组件. 根据列表的适配器 ...

  3. animate.css配合wow.min.js实现各种页面滚动效果

    有的页面在向下滚动的时候,有些元素会产生细小的动画效果.虽然动画比较小,但却能吸引你的注意.比如刚刚发布的 iPhone 6 的页面(查看).如果你希望你的页面也更加有趣,那么你可以试试 WOW.js ...

  4. 一个等待页面加载完毕的loading动画

    1 html 部分 <!DOCTYPE html><html><head><meta http-equiv="Content-Type" ...

  5. Ninject的使用

    摘要 DI容器的一个责任是管理他创建的对象的生命周期.他应该决定什么时候创建一个给定类型的对象,什么时候使用已经存在的对象.他还需要在对象不需要的时候处理对象.Ninject在不同的情况下管理对象的生 ...

  6. Javascript类型

    Javascript 有两中类型:原始类型和对象类型. 原始类型包括:数字,字符串,布尔值,null和undefined.其余的都是对象类型. 原始类型 数字.Javascript采用IEEE754标 ...

  7. CSS()方法设置元素样式

    使用CSS()方法可以直接设置元素的样式,方法为:css(name,value) $(p).css("font-weight", "bold");     // ...

  8. jquery实现页面动态切换的方法--toggleClass(className)

    $(function() { $(".A").click(function() { $(this).toggleClass("B"); }); }); 当点击带 ...

  9. 把表里的数据转换为insert 语句

    当表里面有数据时,怎么把表里的数据转换为insert 语句 (从别人那里看来的用SQLServer 2008 R2测试可用) CREATE PROC spGenInsertSQL @TableName ...

  10. rhel7防止开机破密码

    在/etc/grub.d/00_header文件结尾加入  cat <<EOF set  superusers="qin"#用户名称可以更加自身编辑 password ...