POJ3889 Fractal Streets

我对分治的理解:https://www.cnblogs.com/AKMer/p/9728574.html

题目传送门:http://poj.org/problem?id=3889

据说这种图叫分形图……一般找找规律就好了,像我这种菜鸡也只会做变化小一点的分形图了。

时间复杂度:\(O(能过)\)

空间复杂度:\(O(1)\)

代码如下:

#include <cmath>
#include <cstdio>
using namespace std;

int read() {
    int x=0,f=1;char ch=getchar();
    for(;ch<'0'||ch>'9';ch=getchar())if(ch=='-')f=-1;
    for(;ch>='0'&&ch<='9';ch=getchar())x=(x<<1)+(x<<3)+ch-'0';
    return x*f;
}

struct fuckpps {
    int x,y;
    fuckpps() {}
    fuckpps(int _x,int _y) {
        x=_x,y=_y;
    }
};

fuckpps find(int n,int angle,int id) {
    if(n==1) {
        if(angle==0) {
            if(id==1)return fuckpps(1,1);
            if(id==2)return fuckpps(1,2);
            if(id==3)return fuckpps(2,2);
            if(id==4)return fuckpps(2,1);
        }
        if(angle==1) {
            if(id==1)return fuckpps(1,1);
            if(id==2)return fuckpps(2,1);
            if(id==3)return fuckpps(2,2);
            if(id==4)return fuckpps(1,2);
        }
        if(angle==2) {
            if(id==1)return fuckpps(2,2);
            if(id==2)return fuckpps(2,1);
            if(id==3)return fuckpps(1,1);
            if(id==4)return fuckpps(1,2);
        }
        if(angle==3) {
            if(id==1)return fuckpps(2,2);
            if(id==2)return fuckpps(1,2);
            if(id==3)return fuckpps(1,1);
            if(id==4)return fuckpps(2,1);
        }
    }
    fuckpps res;
    int a=1<<(2*(n-1)),b=a*2,c=a*3;
    if(angle==0) {
        if(id<=a)res=find(n-1,1,id);
        if(id>a&&id<=b) {
            res=find(n-1,0,id-a);
            res.y+=1<<(n-1);
        }
        if(id>b&&id<=c) {
            res=find(n-1,0,id-b);
            res.x+=1<<(n-1);
            res.y+=1<<(n-1);
        }
        if(id>c) {
            res=find(n-1,3,id-c);
            res.x+=1<<(n-1);
        }
    }
    if(angle==1) {
        if(id<=a)res=find(n-1,0,id);
        if(id>a&&id<=b) {
            res=find(n-1,1,id-a);
            res.x+=1<<(n-1);
        }
        if(id>b&&id<=c) {
            res=find(n-1,1,id-b);
            res.x+=1<<(n-1);
            res.y+=1<<(n-1);
        }
        if(id>c) {
            res=find(n-1,2,id-c);
            res.y+=1<<(n-1);
        }
    }
    if(angle==2) {
        if(id<=a) {
            res=find(n-1,3,id);
            res.x+=1<<(n-1);
            res.y+=1<<(n-1);
        }
        if(id>a&&id<=b) {
            res=find(n-1,2,id-a);
            res.x+=1<<(n-1);
        }
        if(id>b&&id<=c)res=find(n-1,2,id-b);
        if(id>c) {
            res=find(n-1,1,id-c);
            res.y+=1<<(n-1);
        }
    }
    if(angle==3) {
        if(id<=a) {
            res=find(n-1,2,id);
            res.x+=1<<(n-1);
            res.y+=1<<(n-1);
        }
        if(id>a&&id<=b) {
            res=find(n-1,3,id-a);
            res.y+=1<<(n-1);
        }
        if(id>b&&id<=c)res=find(n-1,3,id-b);
        if(id>c) {
            res=find(n-1,0,id-c);
            res.x+=1<<(n-1);
        }
    }
    return res;
}//巨恶心的分情况讨论分治

int ABS(int a,int b) {
    if(a>b)return a-b;
    return b-a;
}

int sqr(int a) {
    return a*a;
}

int main() {
    int T=read();
    while(T--) {
        int n=read(),a=read(),b=read();
        fuckpps a1=find(n,0,a),a2=find(n,0,b);
        double gey=sqrt(sqr(ABS(a1.x,a2.x))+sqr(ABS(a1.y,a2.y)));
        int ans=trunc(10*gey+0.5);
        printf("%d\n",ans);
    }
    return 0;
}

原文地址:https://www.cnblogs.com/AKMer/p/9734953.html

时间: 2024-07-31 22:26:58

POJ3889 Fractal Streets的相关文章

poj3889 Fractal Streets 题解报告

题目传送门 [题目大意] 社区的设计有一种特殊的规律,从左上角起沿着道路给房子编号,求给定编号的两间房子的距离. [思路分析] 分析可得社区的设计规律,编号为$n$,即有$4^n$个小格子,每$4^{n-1}$个小格子为一个大格子,即整个图分为四部分,其中右上和右下两部分与编号为$n-1$的相同,左上是顺时针旋转90度的结果,左下是逆时针旋转90度的结果. 代码实现的过程中注意一下这几种不同的情况,计算出坐标后直接求距离. [代码实现] 1 #include<cstdio> 2 #includ

Fractal Streets

POJ 题意:随着越来越大的城市对现代化的不断增长的需求,人们需要新的街道设计.克里斯是负责这些设计的不幸城市规划者之一.每年的需求都在不断增加,今年他甚至被要求设计一个全新的城市.克里斯现在需要做更多的工作,因为像任何好官僚一样,他非常懒惰.鉴于这是他与大多数计算机科学家共同的性格特征,他的一个最亲密的朋友保罗实际上是计算机科学家也就不足为奇了.正是保罗提出了一个让克里斯成为同龄人英雄的好主意:分形街!通过使用希尔伯特曲线,他可以轻松填充任意大小的矩形图,只需很少的工作. 1阶的希尔伯特曲线由

POJ3889Fractal Streets

Fractal Streets Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 445   Accepted: 162 Description With a growing desire for modernization in our increasingly larger cities comes a need for new street designs. Chris is one of the unfortunat

算法竞赛进阶指南做题记录

基本算法 递归与递推 费解的开关 Strange Towers of Hanoi Sumdiv Fractal Streets 前缀和与差分 激光炸弹 IncDec Sequence Tallest Cow 二分 Best Cow Fences 排序 Cinema 货舱选址 七夕祭 Running Median 第K大数 Ultra-QuickSort 奇数码问题 原文地址:https://www.cnblogs.com/Maktub-blog/p/11009723.html

POJ1941 The Sierpinski Fractal

Description Consider a regular triangular area, divide it into four equal triangles of half height and remove the one in the middle. Apply the same operation recursively to each of the three remaining triangles. If we repeated this procedure infinite

uva 11595 - Crossing Streets EXTREME(切割多边形)

题目链接:uva 11595 - Crossing Streets EXTREME 对初始平面进行切割,得到所有平面,然后处理出所有边,有公共边的两个平面之间可以到达,对于城市的权值可以加到点上,进出各加一次即可. #include <cstdio> #include <cstring> #include <cmath> #include <queue> #include <vector> #include <complex> #in

Fractal(递归,好题)

Fractal Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 8341   Accepted: 3965 Description A fractal is an object or quantity that displays self-similarity, in a somewhat technical sense, on all scales. The object need not exhibit exactly

分形树Fractal tree介绍——具体如何结合TokuDB还没有太懂,先记住其和LSM都是一样的适合写密集

在目前的Mysql数据库中,使用最广泛的是innodb存储引擎.innodb确实是个很不错的存储引擎,就连高性能Mysql里都说了,如果不是有什么很特别的要求,innodb就是最好的选择.当然,这偏文章讲的是TokuDB,不是innodb,相比innodb,TokuDB有着自己的特点. 转自:http://www.kryptosx.info/archives/931.html BTree和Fractal tree的比较: 目前无论是SQL Server,还是MySQL的innodb,都是用的B+

POJ 题目2083 Fractal(分治)

Fractal Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 7937   Accepted: 3807 Description A fractal is an object or quantity that displays self-similarity, in a somewhat technical sense, on all scales. The object need not exhibit exactly