QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#597836 | #6412. Classical Geometry Problem | manizare | WA | 0ms | 3812kb | C++14 | 2.4kb | 2024-09-28 19:04:20 | 2024-09-28 19:04:20 |
Judging History
answer
#include <bits/stdc++.h>
#define pb push_back
#define F first
#define S second
#define sz(a) (int)a.size()
#define pii pair<int,int>
#define rep(i , a , b) for(int i = (a) ; i <= (b) ; i++)
#define per(i , a , b) for(int i = (a) ; i >= (b) ; i--)
#define all(a) a.begin(),a.end()
#define int long long
#define ld long double
using namespace std ;
mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
const int maxn =2e5 + 10 , mod = 998244353 , inf= 1e10 ;;
struct po{
ld a[3] ;
};
vector <pair<ld,po> > vec ;
void go(po a , ld d){
vec.pb({d , a}) ;
}
ld sq(ld f){
ld l= 0 , r =1e9 ;
rep(i , 1 , 60){
ld mid = (l+r)/(ld)2;
if((mid*mid) <= f){
l = mid ;
}else{
r = mid ;
}
}
return l ;
}
ld dis(po a, po b){
int ans =0 ;
rep(i , 0 ,2){
ans += abs(a.a[i]-b.a[i]) * abs(a.a[i]-b.a[i]) ;
}
return sq((ld)ans);
}
int is(po f){
bool ok =0 ;
rep(i , 0 ,2){
if(f.a[i] < 0 && f.a[i] > 255){
ok = 1;
}
}
return !ok ;
}
po st ;
void f(po x){
int s =0 ;
rep(i , 0, 2){
if(x.a[i] ==0 || x.a[i]==255){
s++;
}
}
if(s == 3){
go(x , dis(st , x));
return ;
}
if(s==2){
po x2 = x , x3 = x ;
rep(i ,0 ,2){
if(x.a[i]!=0 && x.a[i]!=255){
x2.a[i]=0 ;
x3.a[i]=255;
}
}
f(x2) ;
go(x3 , dis(x2 , x)) ;
return ;
}
if(s==1){
vector <int> vec ;
rep(i , 0 , 2){
if(x.a[i]!=0 && x.a[i]!=255){
vec.pb(i);
}
}
ld m = x.a[vec[1]]/x.a[vec[0]] ;
po f1 = x , f2 =x , k= x ;
k.a[vec[0]] = k.a[vec[1]] = 0 ;
f1.a[vec[0]] = 255 ;f2.a[vec[1]] = 255 ;
f2.a[vec[0]] = (ld)255/m ;f1.a[vec[1]] = (ld)255*m ;
if(is(f1) == 0)f1 = f2 ;
f(f1) ;
go(k , dis(f1 , x));
return ;
}
rep(i , 0 ,2){
po b ;
b.a[i] = 255 ;
rep(j , 0 ,2){
if(j == i)continue ;
ld m = x.a[j]/x.a[i] ;
b.a[j] = m*(ld)255 ;
}
if(is(b) == 1){
f(b);
go(st , dis(b , x)) ;
break ;
}
}
}
int ch(int x){
if(x==0)return 0;
return 255 ;
}
signed main(){
ios::sync_with_stdio(0);cin.tie(0);
rep(i , 0 ,2)st.a[i] = 0 ;
int T ;
cin >> T ;
while(T--){
po b;
rep(i ,0 ,2)cin >> b.a[i] ;
vec.clear() ;
f(b);
cout<<sz(vec) << "\n" ;
rep(i ,0 , sz(vec)-1){
po v = vec[i].S ; ld d = vec[i].F ;
rep(i ,0 ,2)cout << v.a[i] << " " ;
cout << setprecision(8) << d << "\n" ;
}
}
}
/*
*/
詳細信息
Test #1:
score: 0
Wrong Answer
time: 0ms
memory: 3812kb
input:
3 105 255 175 174 174 174 0 0 0
output:
3 255 255 0 360.62446 255 255 255 425 0 255 0 291.54759 2 255 255 255 441.67296 0 0 0 140.29612 1 0 0 0 0
result:
wrong answer too far from the target: (48.844722, 255.000000, 48.844722) instead of (105, 255, 175) (test case 1)