点的变换

时间限制:2000 ms  |  内存限制:65535 KB
难度:5
描写叙述

平面上有不超过10000个点。坐标都是已知的。如今可能对全部的点做下面几种操作:

平移一定距离(M),相对X轴上下翻转(X),相对Y轴左右翻转(Y),坐标缩小或放大一定的倍数(S),全部点对坐标原点逆时针旋转一定角度(R)。

操作的次数不超过1000000次,求终于全部点的坐标。

提示:假设程序中用到PI的值,能够用acos(-1.0)获得。

输入
仅仅有一组測试数据

測试数据的第一行是两个整数N,M,分别表示点的个数与操作的个数(N<=10000,M<=1000000)

随后的一行有N对数对,每一个数对的第一个数表示一个点的x坐标,第二个数表示y坐标。这些点初始坐标大小绝对值不超过100。

随后的M行,每行代表一种操作,行首是一个字符:

首字符假设是M,则表示平移操作。该行后面将跟两个数x,y。表示把全部点按向量(x,y)平移;

首字符假设是X。则表示把全部点相对于X轴进行上下翻转;

首字符假设是Y,则表示把全部点相对于Y轴进行左右翻转;

首字符假设是S。则随后将跟一个数P,表示坐标放大P倍;

首字符假设是R,则随后将跟一个数A,表示全部点相对坐标原点逆时针旋转一定的角度A(单位是度)
输出
每行输出两个数。表示一个点的坐标(对结果四舍五入到小数点后1位,输出一位小数位)

点的输出顺序应与输入顺序保持一致
例子输入
2 5
1.0 2.0 2.0 3.0
X
Y
M 2.0 3.0
S 2.0
R 180
例子输出
-2.0 -2.0
0.0 0.0

分析:假设依照题目描写叙述的那样模拟。肯定会超时。这时就要找一种高速变换的方法。

这样就能够先算出经过M次变换后形成的终于矩形,然后用点的坐标乘以矩形就能够求出答案。

#include <cstdio>
#include <cstring>
#include <cmath>
#define PI acos(-1.0) struct Matrix {
double mat[3][3];
Matrix() {
memset(mat, 0, sizeof(mat));
for(int i = 0; i < 3; i++)
mat[i][i] = 1;
} Matrix Multi(Matrix A, Matrix B) {
Matrix res;
for(int i = 0; i < 3; i++) {
for(int j = 0; j < 3; j++) {
res.mat[i][j] = 0;
for(int k = 0; k < 3; k++) {
res.mat[i][j] = res.mat[i][j] + A.mat[i][k] * B.mat[k][j];
}
}
}
return res;
} Matrix Translation(Matrix A, double p, double q) { //向上平移p个单位,向右平移q个单位
Matrix res;
res.mat[0][2] = p;
res.mat[1][2] = q;
return Multi(res, A);
} Matrix Scale(Matrix A, double p) { //缩放p倍
Matrix res;
res.mat[0][0] = res.mat[1][1] = p;
return Multi(res, A);
} Matrix Turn_UD(Matrix A) { //坐标轴上下翻转
Matrix res;
res.mat[1][1] = -1;
return Multi(res, A);
} Matrix Turn_LR(Matrix A) { //坐标轴左右翻转
Matrix res;
res.mat[0][0] = -1;
return Multi(res, A);
} Matrix Rotate(Matrix A, double angle) { //绕原点逆时针旋转angle角度
double rad = angle / 180.0 * PI;
Matrix res;
res.mat[0][0] = cos(rad); res.mat[0][1] = -sin(rad);
res.mat[1][0] = sin(rad); res.mat[1][1] = cos(rad);
return Multi(res, A);
}
}; struct Point {
double x, y;
} P[10005]; int main() {
int n, m;
char op[5];
double x, y;
scanf("%d%d", &n, &m);
for(int i = 0; i < n; i++)
scanf("%lf%lf", &P[i].x, &P[i].y);
Matrix A;
for(int i = 0; i < m; i++) {
scanf("%s", op);
if(op[0] == 'X') A = A.Turn_UD(A);
else if(op[0] == 'Y') A = A.Turn_LR(A);
else if(op[0] == 'M') {
scanf("%lf%lf", &x, &y);
A = A.Translation(A, x, y);
}
else if(op[0] == 'S') {
scanf("%lf", &x);
A = A.Scale(A, x);
}
else if(op[0] == 'R') {
scanf("%lf", &x);
A = A.Rotate(A, x);
}
}
for(int i = 0; i < n; i++) {
double xx = A.mat[0][0] * P[i].x + A.mat[0][1] * P[i].y + A.mat[0][2];
double yy = A.mat[1][0] * P[i].x + A.mat[1][1] * P[i].y + A.mat[1][2];
printf("%.1lf %.1lf\n", xx, yy);
}
return 0;
}

版权声明:本文博客原创文章,博客,未经同意,不得转载。

NYOJ 298 相变点(矩阵高速功率)的更多相关文章

  1. [POJ 3735] Training little cats (结构矩阵、矩阵高速功率)

    Training little cats Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 9613   Accepted: 2 ...

  2. hdu 2243 考研绝望——复杂的文字(AC自己主动机+矩阵高速功率)

    pid=2243" target="_blank" style="">题目链接:hdu 2243 考研路茫茫--单词情结 题目大意:略. 解题思 ...

  3. UVA 10870 - Recurrences(矩阵高速功率)

    UVA 10870 - Recurrences 题目链接 题意:f(n) = a1 f(n - 1) + a2 f(n - 2) + a3 f(n - 3) + ... + ad f(n - d), ...

  4. poj 3744 Scout YYF I (可能性DP+矩阵高速功率)

    Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 5062   Accepted: 1370 Description YYF i ...

  5. POJ 3070 Fibonacci(矩阵高速功率)

    职务地址:POJ 3070 用这个题学会了用矩阵高速幂来高速求斐波那契数. 依据上个公式可知,第1行第2列和第2行第1列的数都是第n个斐波那契数.所以构造矩阵.求高速幂就可以. 代码例如以下: #in ...

  6. HDU 2842 Chinese Rings(矩阵高速功率+递归)

    职务地址:HDU 2842 这个游戏是一个九连环的游戏. 如果当前要卸下前n个环.由于要满足前n-2个都卸下,所以要先把前n-2个卸下.须要f(n-2)次.然后把第n个卸下须要1次,然后这时候要卸下第 ...

  7. NYOJ 300 &amp;&amp; hdu 2276 Kiki &amp; Little Kiki 2 (矩阵高速功率)

    pid=300">Kiki & Little Kiki 2 时间限制:5000 ms  |  内存限制:65535 KB 难度:4 描写叙述 There are n light ...

  8. VOJ 1067 Warcraft III 守望者的烦恼 (矩阵高速功率+dp)

    主题链接 明显的 dp[n] = dp[n-k] + dp[n-k+1] + ... +dp[n-1]; 然后要用矩阵来优化后面的状态转移. 也就是矩阵 0 1 0 0    a     b 0 0 ...

  9. HDU 4896 Minimal Spanning Tree(矩阵高速功率)

    意甲冠军: 给你一幅这样子生成的图,求最小生成树的边权和. 思路:对于i >= 6的点连回去的5条边,打表知907^53 mod 2333333 = 1,所以x的循环节长度为54,所以9个点为一 ...

随机推荐

  1. [HTTP] Understand 2xx HTTP Status Code Responses

    The 2xx family of status codes are used in HTTP responses to indicate success. Beyond the generic 20 ...

  2. [AngularFire 2] Protect Write Access Using Security Rules

    We cannot allow un-auth user to change the database data as they want, for Firebase, it is easy just ...

  3. [CSS] Showing horizontal scrollbar always for the table

    table { display: block; overflow: scroll; width: 200px; height:95vh; }

  4. [RxJS] Split an RxJS observable conditionally with windowToggle

    There are variants of the window operator that allow you to split RxJS observables in different ways ...

  5. js如何实现动态在表格中添加标题和去掉标题?

    js如何实现动态在表格中添加标题和去掉标题? 一.总结 1.通过table标签的createCaption(),deleteCaption()方法实现. document.getElementById ...

  6. 【poj1442】Black Box

    Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 10890   Accepted: 4446 Description Our ...

  7. ie7easyui的书写要规范

    在书写easyui对象的属性,有时候习惯在,属性的末尾再加一个“,”,这个在高版本浏览器是没事的,但是在ie7及以下,会有报错

  8. springMVC返回json数据乱码问题及@RequestMapping 详解

    原文地址:https://blog.csdn.net/u010127245/article/details/51774074 一.@RequestMapping RequestMapping是一个用来 ...

  9. 一大波Java来袭(四)String类、StringBuilder类、StringBuffer类对照

    本文主要介绍String类.StringBuffer类.StringBuilder类的差别  : 一.概述 (一)String 字符串常量.可是它具有不可变性,就是一旦创建,对它进行的不论什么改动操作 ...

  10. 【hdu 3951】Coin Game

    Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s) ...