青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

oyjpArt ACM/ICPC算法程序設(shè)計空間

// I am new in programming, welcome to my blog
I am oyjpart(alpc12, 四城)
posts - 224, comments - 694, trackbacks - 0, articles - 6

SRM401 550 PTS ParticleCollision

Posted on 2008-05-07 02:32 oyjpart 閱讀(2226) 評論(0)  編輯 收藏 引用 所屬分類: ACM/ICPC或其他比賽

Problem Statement

    

Particles (which can be considered points in 3D-space for the purposes of the problem) can move in an electro-magnetic field. If a particle is charged, its trajectory can be described as spiral, and if it is uncharged, it is just a straight line. Given two particles (one charged and one uncharged) it should be determined whether they can possibly collide or not. Two particles can possibly collide if and only if their trajectories intersect.

Some steps have already been made by the physicist to simplify the problem, so the coordinates of the charged particle are represented as follows:

x1 = cos(PI * t)

y1 = sin(PI * t)

z1 = t

and for the uncharged particle:

x2 = vx * t + x0

y2 = vy * t + y0

z2 = vz * t + z0

Here t is a parameter which can be chosen arbitrarily and independently for both trajectories.

Your method will be given 6 integers - vx, vy, vz, x0, y0 and z0, describing the trajectory of the uncharged particle. It should determine whether the two given trajectories intersect or not. If they do, it should return a vector <double> containing exactly 3 elements x, y and z - the coordinates of the point where a collision can happen. If there is more than one such point, it should return a vector <double> containing exactly three zeroes. If collision of the two particles is impossible it should return an empty vector <double>.

Definition

    
Class: ParticleCollision
Method: collision
Parameters: int, int, int, int, int, int
Returns: vector <double>
Method signature: vector <double> collision(int vx, int vy, int vz, int x0, int y0, int z0)
(be sure your method is public)
    

Notes

- PI can be considered equal to 3.14159265358979323846.
- All return values with either an absolute or relative error of less than 1.0E-9 are considered correct.

Constraints

- vx, vy and vz will each be between -10 and 10, inclusive.
- x0, y0 and z0 will each be between -10 and 10, inclusive.

Examples

0)
    
0
0
0
0
0
0
Returns: { }
The second trajectory is a single point (0, 0, 0), which doesn't lie on the first trajectory.
1)
    
2
4
1
-1
-1
0
Returns: {0.0, 1.0, 0.5 }
There is a single intersection point with coordinates (0, 1, 0.5).
2)
    
4
4
2
5
4
0
Returns: {0.0, 0.0, 0.0 }
There are two intersection points.
3)
    
0
0
1
1
0
0
Returns: {0.0, 0.0, 0.0 }
There are infinitely many intersection points.

This problem statement is the exclusive and proprietary property of TopCoder, Inc. Any unauthorized use or reproduction of this information without the prior written consent of TopCoder, Inc. is strictly prohibited. (c)2003, TopCoder, Inc. All rights reserved.


要做這道題,要注意很多問題:
1.看清題,題目中說了t是independent
2.解一元二次方程要會吧!系數(shù)A,B,C的判定不要漏掉
3.特殊情況下A=B=C什么時候有解考慮清楚

這樣你就可以過題了!!!

#pragma warning ( disable : 4786 )

#include <vector>
#include <list>
#include <map>
#include <set>
#include <deque>
#include <stack>
#include <bitset>
#include <queue>
#include <algorithm>
#include <functional>
#include <numeric>
#include <utility>
#include <sstream>
#include <iostream>
#include <iomanip>
#include <cstdio>
#include <cmath>
#include <cstdlib>
#include <ctime>

using namespace std;

const double PI = acos(-1.0);

#define sz(x) ((int)(x).size())
#define Max(a,b) ((a)>(b)?(a):(b))
#define Min(a,b) ((a)<(b)?(a):(b))
#define MAXINT 1000000000
#define EPS 1e-8
#define FOR(a,b,c) for(a=(b);(a)<(c);++(a))
#define REP(a,b) FOR(a,0,b)
typedef vector<int> VI;

inline int dblcmp(double a, double b) {
    if(fabs(a-b) < EPS) return 0;
    return a < b ? -1 : 1;
}

//typedef long long LL;

/*
cos(PI * t1)=vx * t2 + x0
sin(PI * t1)=vy * t2 + y0
t1=vz*t2+z0
*/


class ParticleCollision
{
public:
    int vx, vy, vz, x0, y0, z0;

    bool check(double t2) {
        double x2 = vx * t2 + x0;
        double y2 = vy * t2 + y0;
        double t1 = vz * t2 + z0;

        if(dblcmp(cos(PI * t1), vx * t2 + x0)==0
            && dblcmp(sin(PI * t1),vy * t2 + y0)==0
            && dblcmp(t1,vz*t2+z0)==0)
            return true;
        return false;

    }
    vector <double> collision(int _vx, int _vy, int _vz, int _x0, int _y0, int _z0)
    {
        vz=1;
        vx = _vx;
        vy = _vy;
        vz = _vz;
        x0 = _x0;
        y0 = _y0;
        z0 = _z0;
        vector<double> mul(3, 0.0);
        vector<double> empty;
        int i, j;
        double a = vx*vx + vy*vy;
        double b = 2 * vx * x0 + 2 * vy * y0;
        double c = x0 * x0 + y0 * y0 - 1;
    //    printf("a = %lf b = %lf c = %lf\n", a, b, c);
        double det = b*b-4 * a * c;
        if(dblcmp(a, 0.0) == 0) {
            if(dblcmp(b, 0.0) == 0) {
                if(dblcmp(c, 0.0) == 0) {
                    if(dblcmp(vz, 0.0) == 0) {
                        if(dblcmp(x0, cos(PI * z0)) == 0
                            && dblcmp(y0, sin(PI * z0)) == 0) {
                            vector<double> ret;
                            ret.push_back(x0);
                            ret.push_back(y0);
                            ret.push_back(z0);
                            return ret;
                        }
                    }
                    else return mul;
                }
                return empty;
            }
            double t = -c / b;
            if(check(t)) {
                vector<double> ret;
                ret.push_back(vx * t + x0);
                ret.push_back(vy * t + y0);
                ret.push_back(vz * t + z0);
                return ret;
            }
            return empty;
        }
    //    printf("det = %lf\n", det);
        int x = dblcmp(det, 0);
        if(x == 1) {
            int cnt = 0;
            vector<double> ret;
            for(i = 0; i < 2; ++i) {
                double t;
                if(i == 0) t = (-b - sqrt(det)) / 2 / a;
                if(i == 1) t = (-b + sqrt(det)) / 2 / a;
                
                if(check(t)) {
                    ret.push_back(vx * t + x0);
                    ret.push_back(vy * t + y0);
                    ret.push_back(vz * t + z0);
                    cnt++;
                }
            }
            if(cnt == 0) return empty;
            else if(cnt == 1) return ret;
            else return mul;
        }
        else if( x== -1) return empty;
        else {
            double t = (-b + sqrt(det)) / 2 / a;
            if(check(t)) {
                vector<double> ret;
                ret.push_back(vx * t + x0);
                ret.push_back(vy * t + y0);
                ret.push_back(vz * t + z0);
                return ret;
            }
            return empty;
        }
    }
   
 
};



// Powered by FileEdit
// Powered by TZTester 1.01 [25-Feb-2003]
// Powered by CodeProcessor
 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲一区免费观看| 亚洲伊人观看| 欧美成人久久| 欧美r片在线| 一本久道久久久| 一区二区三区精密机械公司| 国产精品久久久一区麻豆最新章节 | 亚洲日本中文字幕区| 欧美不卡视频一区发布| 亚洲精品一区二区三区樱花| 亚洲美女尤物影院| 国产精品久久久久三级| 久久免费黄色| 欧美激情自拍| 久久福利电影| 欧美大片在线看| 午夜欧美电影在线观看| 久久婷婷亚洲| 亚洲综合日韩| 美国三级日本三级久久99| 一本色道精品久久一区二区三区 | 亚洲男人天堂2024| 久久成人在线| 亚洲视频免费观看| 欧美在线免费看| 艳妇臀荡乳欲伦亚洲一区| 亚洲综合色丁香婷婷六月图片| 在线观看国产日韩| 亚洲视频999| 亚洲清纯自拍| 欧美亚洲免费| 亚洲视频在线观看网站| 久久久久9999亚洲精品| 亚洲午夜视频在线| 久久最新视频| 久久久久在线观看| 欧美日韩精品三区| 你懂的视频欧美| 国产精品成人va在线观看| 欧美大片18| 国内精品久久久| 亚洲一区视频在线观看视频| 亚洲美女啪啪| 你懂的视频一区二区| 欧美一区三区三区高中清蜜桃| 欧美日韩黄色大片| 欧美激情国产日韩精品一区18| 国产精品久久久久久一区二区三区 | 国产日韩在线不卡| 亚洲精品小视频在线观看| 亚洲第一页自拍| 性欧美大战久久久久久久免费观看 | 久久综合国产精品| 久久久精品性| 国产视频亚洲精品| 亚洲专区一二三| 亚洲一区中文| 欧美午夜片欧美片在线观看| 亚洲日本国产| 一本色道**综合亚洲精品蜜桃冫| 欧美黄色小视频| 亚洲人成绝费网站色www| 亚洲国产影院| 欧美成人嫩草网站| 亚洲国产乱码最新视频| 亚洲人人精品| 欧美精品在线极品| 日韩视频一区二区三区在线播放免费观看 | 久久精品亚洲热| 国精品一区二区三区| 久久福利一区| 免费短视频成人日韩| 亚洲国产精品嫩草影院| 欧美高清在线观看| 99热这里只有精品8| 亚洲无线视频| 国产精品主播| 久久久久久成人| 欧美激情在线观看| 99天天综合性| 国产精品一区二区在线| 欧美在线国产| 欧美黄色免费| 亚洲一区二区三区精品视频| 国产欧美一区二区在线观看| 久久精品综合网| 91久久视频| 欧美亚洲专区| 亚洲大片av| 欧美日韩一区二区三区四区在线观看 | 欧美资源在线观看| 在线精品在线| 欧美日韩免费观看一区三区 | 亚洲性夜色噜噜噜7777| 久久精品系列| 亚洲美女诱惑| 国产精品夜色7777狼人| 久久综合九色九九| 一区二区精品在线观看| 久久综合国产精品台湾中文娱乐网 | 欧美在线资源| 亚洲精品影院| 久久久久久久一区| 在线亚洲观看| 伊人婷婷欧美激情| 国产精品草草| 麻豆精品在线视频| 亚洲综合社区| 亚洲精品一区二区网址| 久久综合一区二区| 亚洲一区图片| 亚洲巨乳在线| 狠狠综合久久| 国产精品久久99| 欧美激情片在线观看| 久久久国产成人精品| 亚洲一区二区在线| 亚洲欧洲精品一区二区| 久久综合色综合88| 欧美一区二区三区在线播放| 这里只有精品在线播放| 亚洲国产精品一区二区第四页av | 欧美成人一品| 久久高清免费观看| 亚洲男女自偷自拍| 一本久道久久综合婷婷鲸鱼| 亚洲国产成人porn| 欧美成人69| 久久另类ts人妖一区二区| 午夜欧美大尺度福利影院在线看| 99精品久久久| 99精品国产99久久久久久福利| 亚洲国产精品久久久久秋霞影院| 狠狠88综合久久久久综合网| 国产午夜精品久久久久久久| 国产精品区一区| 欧美亚男人的天堂| 欧美午夜免费影院| 国产精品成人一区二区三区吃奶| 欧美日韩精品一区二区| 欧美激情四色 | 久久久久久国产精品一区| 午夜激情综合网| 亚洲欧美视频一区二区三区| 亚洲一级黄色| 欧美在线网站| 久久精品国产在热久久 | 亚洲风情亚aⅴ在线发布| 久久亚洲私人国产精品va| 久久影视精品| 欧美国产高潮xxxx1819| 亚洲黄色在线看| 亚洲美女视频网| 亚洲欧美国产毛片在线| 欧美一区二区在线观看| 久久久久久久综合色一本| 麻豆国产精品va在线观看不卡| 蜜臀久久99精品久久久画质超高清| 久久久久久日产精品| 欧美成人午夜激情视频| 欧美日韩一区二区在线观看| 国产精品久久久久久久久婷婷 | 欧美精品www在线观看| 欧美日韩成人综合| 国产精品视频你懂的| 国内精品一区二区| 亚洲精品一区二区三区在线观看 | 亚洲电影第1页| 亚洲精品网址在线观看| 亚洲在线不卡| 裸体歌舞表演一区二区 | 性亚洲最疯狂xxxx高清| 久久亚洲国产精品一区二区| 亚洲日本无吗高清不卡| 亚洲一区视频| 免费在线亚洲| 国产精品久久久久久久久搜平片| 影音先锋国产精品| 亚洲少妇中出一区| 免费在线观看一区二区| 日韩一级免费| 久久久亚洲一区| 国产精品黄色在线观看| 亚洲国产第一页| 午夜精品在线观看| 亚洲国产裸拍裸体视频在线观看乱了中文| 在线午夜精品自拍| 免费成人网www| 国产日韩亚洲欧美综合| 中文一区在线| 亚洲福利视频一区二区| 午夜在线视频观看日韩17c| 欧美久久久久免费| 精久久久久久| 欧美影院在线| 一区二区日韩| 欧美精品久久一区| 亚洲高清久久| 老司机精品视频网站| 亚洲欧美日本国产有色|