• D. Vasya and Triangle(思维, 三角形)


     传送门

    题意: 给你 n, m, k, 问你是否存在一个三角形, 满足三角形的面积等于 n * m / k;

        若存在, 输出YES, 且输出满足条件的三角形的三个坐标(答案有多种,则输出任意一种)

             且三角形的三个坐标,都满足, 0 <= xi <= n, 0 <= yi <= m;

        若不存在,输出NO;

    解: 首先, 我们知道, 对于任意一个满足条件的三角形, 我们可以通过, 旋转, 平移。

       把他一个顶点移动到原点,另一个顶点移动到,y坐标轴或者x坐标轴。 

       即将三角形的一条边移动到,坐标轴,且其中一个点在原点。

       然后, 我们知道了三角形的三个顶点的坐标,则面积公式为:

      S=(1/2)*(x1y2+x2y3+x3y1-x1y3-x2y1-x3y2) = n * m / k;

      然后, 根据上面的性质, 你就可以得到

      x1 * y2 = 2 * n * m / k;

      然后, 对于 2 * n * m % k == 0 的情况, 一定有解, 判断一下 gcd(2 * n, k) ;

      若gcd = 1, 则 m 一定整除 k; 则, x1 = n, y2 = 2 * m / k;

      否则,x1 =  2 * n / gcd, y1 = m * gcd / k;

    #include <bits/stdc++.h>
    #define LL long long
    using namespace std;
    int main() {
        LL n, m, k; scanf("%lld %lld %lld", &n, &m, &k);
        if(2LL * n * m % k != 0) puts("NO");
        else {
            puts("YES"); puts("0 0");
            LL gcd = __gcd(2LL * n, k);
            if(gcd == 1) {
                printf("%lld 0
    ", n);
                printf("0 %lld
    ", 2LL * m / k);
            }
            else {
                printf("%lld 0
    ", 2LL * n / gcd);
                printf("0 %lld
    ", m * gcd / k);
            }
        }
        return 0;
    }
    View Code
    一步一步,永不停息
  • 相关阅读:
    洛谷P3275 [SCOI2011]糖果
    2018年12月30&31日
    洛谷P4114 Qtree1
    洛谷P4116 Qtree3
    洛谷P4315 月下“毛景树”
    洛谷P1505 [国家集训队]旅游
    洛谷P2253 好一个一中腰鼓!
    CF616D Longest k-Good Segment
    洛谷P3979 遥远的国度
    洛谷P2486 [SDOI2011]染色
  • 原文地址:https://www.cnblogs.com/Willems/p/12039051.html
Copyright © 2020-2023  润新知