• [BZOJ5044]岛屿生成


    [BZOJ5044]岛屿生成

    试题描述

    小Q设计了一款2D游戏,它的地图建立在二维笛卡尔坐标系上。这个游戏最大的特色就是可以随机生成地图,但是岛屿生成却给小Q带来了巨大的麻烦。一个岛屿可以看成一个恰好有 (n) 个顶点的简单多边形,每个顶点的坐标都必须是整数,同时为了防止精度误差,每条边的长度也必须是整数。为了体现程序的随机性,任何一条边都不能与 (x) 轴或者 (y) 轴平行。当然,这个多边形不能自交,也不允许连续 (3) 个点共线。请写一个程序帮助小Q实现岛屿生成功能。

    输入

    第一行包含一个正整数 (n(3 leq n leq 1000)),表示多边形的点数。

    输出

    输出 (n) 行,每行两个整数 (x_i,y_i(|x_i|,|y_i| leq 10000)),按顺时针或者逆时针顺序依次输出每个顶点的坐标。

    若有多组解,输出任意一组。

    输入示例

    3
    

    输出示例

    0 0
    4 3
    -20 21
    

    数据规模及约定

    见“输入”和“输出

    题解

    有趣的构造题。

    考验想象力的时候到了。

    #include <iostream>
    #include <cstdio>
    #include <cstdlib>
    #include <cstring>
    #include <cctype>
    #include <algorithm>
    using namespace std;
    
    const int BufferSize = 1 << 16;
    char buffer[BufferSize], *Head, *Tail;
    inline char Getchar() {
    	if(Head == Tail) {
    		int l = fread(buffer, 1, BufferSize, stdin);
    		Tail = (Head = buffer) + l;
    	}
    	return *Head++;
    }
    int read() {
    	int x = 0, f = 1; char c = Getchar();
    	while(!isdigit(c)){ if(c == '-') f = -1; c = Getchar(); }
    	while(isdigit(c)){ x = x * 10 + c - '0'; c = Getchar(); }
    	return x * f;
    }
    
    int main() {
    	int n = read();
    	
    	if(n == 3) return puts("0 0
    4 3
    -20 21"), 0;
    	int x = 0;
    	if(n & 1) {
    		puts("0 0
    -32 -24
    40 72
    136 0");
    		int m = n - 4 >> 1; x = 136;
    		for(int i = 1; i <= m; i++, x += 8) printf("%d 3
    %d 0
    ", x + 4, x + 8);
    	}
    	else {
    		puts("0 0");
    		int m = n - 1 >> 1;
    		for(int i = 1; i <= m; i++, x += 8) printf("%d 3
    %d 0
    ", x + 4, x + 8);
    	}
    	printf("%d -%d
    ", x >> 1, (x >> 1) / 4 * 3);
    	
    	return 0;
    }
    
  • 相关阅读:
    创建自定义图标和图像
    使用_CRTDBG_LEAK_CHECK_DF检查VC程序的内存泄漏(转)
    Hadoop Netflix数据统计分析2(转)
    系统提供的按钮和图标
    STATIC变量问题
    表格视图,文本视图和Web视图
    Hadoop Netflix数据统计分析1(转)
    获取程序数据路径(转)
    C++中STRING转为INT (转)
    netflix 推荐算法学习1(转)
  • 原文地址:https://www.cnblogs.com/xiao-ju-ruo-xjr/p/7625585.html
Copyright © 2020-2023  润新知