QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#644919 | #6412. Classical Geometry Problem | ucup-team073# | AC ✓ | 20ms | 3980kb | C++20 | 4.1kb | 2024-10-16 16:00:49 | 2024-10-16 16:00:57 |
Judging History
answer
#include<bits/stdc++.h>
#ifdef LOCAL
#define debug(...) printf(__VA_ARGS__)
#define edebug(...) fprintf(stderr, __VA_ARGS__)
#else
#define debug(...)
#define edebug(...)
#endif
#define int ll
#define rep(i, x, y) for(int i = x; i <= y; ++i)
#define nrep(i, x, y) for(int i = x; i >= y; --i)
#define ll long long
#define pii std::pair<int,int>
#define pb emplace_back
#define fi first
#define se second
template <class T>
inline void ckmax(T &a, T b) {
if(a < b) a = b;
}
template <class T>
inline void ckmin(T &a, T b) {
if(a > b) a = b;
}
auto rt_YES = []{puts("YES");};
auto rt_Yes = []{puts("Yes");};
auto rt_NO = []{puts("NO");};
auto rt_No = []{puts("No");};
namespace IO {
#define isdigit(x) (x >= '0' && x <= '9')
inline char gc() {
return getchar();
}
inline bool blank(char ch) {
return ch == ' ' || ch == '\n' || ch == '\r' || ch == '\t';
}
template <class T>
inline void read(T &x) {
double tmp = 1;
bool sign = 0;
x = 0;
char ch = gc();
for(; !isdigit(ch); ch = gc())
if(ch == '-') sign = 1;
for(; isdigit(ch); ch = gc())
x = x * 10 + (ch - '0');
if(ch == '.')
for(ch = gc(); isdigit(ch); ch = gc())
tmp /= 10.0, x += tmp * (ch - '0');
if(sign) x = -x;
}
inline void read(char *s) {
char ch = gc();
for(; blank(ch); ch = gc());
for(; !blank(ch); ch = gc())
*s++ = ch;
*s = 0;
}
inline void read(char &c) {
for(c = gc(); blank(c); c = gc());
}
inline void push(const char &c) {
putchar(c);
}
template <class T>
inline void print(T x) {
if(x < 0) {
x = -x;
push('-');
}
static T sta[35];
T top = 0;
do {
sta[top++] = x % 10;
x /= 10;
} while(x);
while(top)
push(sta[--top] + '0');
}
template <class T>
inline void print(T x, char lastChar) {
print(x);
push(lastChar);
}
}
using namespace IO;
struct node{int x,y,z;double dis;}a[10];
int cnt=0;
void solve(){
int x,y,z;read(x),read(y),read(z);
if(!(x||y||z)){puts("0");return;}
double X,Y,Z;
cnt=0;
if(x>=y&&x>=z){
X=255;
Y=255.0/x*y;
Z=255.0/x*z;
a[++cnt]={255,0,0,255};
if(Y>Z){
double T=(255-Y)/(255-Z)*255;
a[++cnt]={255,255,0,255-T};
a[++cnt]={255,255,255,sqrt(Z*Z+(Y+T-255)*(Y+T-255))};
}
else if(Z>Y){
double T=(255-Z)/(255-Y)*255;
a[++cnt]={255,0,255,255-T};
a[++cnt]={255,255,255,sqrt(Y*Y+(Z+T-255)*(Z+T-255))};
}
else a[++cnt]={255,255,255,sqrt(Y*Y*2)};
a[++cnt]={0,0,0,sqrt((X-x)*(X-x)+(Y-y)*(Y-y)+(Z-z)*(Z-z))};
}else if(y>=x&&y>=z){
X=255.0/y*x;
Y=255.0;
Z=255.0/y*z;
a[++cnt]={0,255,0,255};
if(X>Z){
double T=(255-X)/(255-Z)*255;
a[++cnt]={255,255,0,255-T};
a[++cnt]={255,255,255,sqrt(Z*Z+(X+T-255)*(X+T-255))};
}
else if(Z>X){
double T=(255-Z)/(255-X)*255;
a[++cnt]={0,255,255,255-T};
a[++cnt]={255,255,255,sqrt(X*X+(Z+T-255)*(Z+T-255))};
}
else a[++cnt]={255,255,255,sqrt(X*X*2)};
a[++cnt]={0,0,0,sqrt((X-x)*(X-x)+(Y-y)*(Y-y)+(Z-z)*(Z-z))};
}else{
X=255.0/z*x;
Y=255.0/z*y;
Z=255.0;
a[++cnt]={0,0,255,255};
if(X>Y){
double T=(255-X)/(255-Y)*255;
a[++cnt]={255,0,255,255-T};
a[++cnt]={255,255,255,sqrt(Y*Y+(X+T-255)*(X+T-255))};
}
else if(Y>X){
double T=(255-Y)/(255-X)*255;
a[++cnt]={0,255,255,255-T};
a[++cnt]={255,255,255,sqrt(X*X+(Y+T-255)*(Y+T-255))};
}
else a[++cnt]={255,255,255,sqrt(Y*Y*2)};
a[++cnt]={0,0,0,sqrt((X-x)*(X-x)+(Y-y)*(Y-y)+(Z-z)*(Z-z))};
}
print(cnt,'\n');
rep(i,1,cnt)printf("%lld %lld %lld %.12lf\n",a[i].x,a[i].y,a[i].z,a[i].dis);
}
signed main() {
clock_t c1 = clock();
#ifdef LOCAL
freopen("in.in", "r", stdin);
freopen("out.out", "w", stdout);
#endif
//------------------------------------------------------------------
int t;read(t);while(t--)solve();
//------------------------------------------------------------------
end:
std::cerr << "Time : " << clock() - c1 << " ms" << std::endl;
return 0;
}
詳細信息
Test #1:
score: 100
Accepted
time: 0ms
memory: 3916kb
input:
3 105 255 175 174 174 174 0 0 0
output:
4 0 255 0 255.000000000000 0 255 255 119.000000000000 255 255 255 119.000000000000 0 0 0 0.000000000000 3 255 0 0 255.000000000000 255 255 255 360.624458405139 0 0 0 140.296115413079 0
result:
ok ok (3 test cases)
Test #2:
score: 0
Accepted
time: 19ms
memory: 3856kb
input:
10000 250 128 13 1 245 2 88 183 138 179 69 194 153 246 33 255 119 192 233 30 108 26 208 33 53 162 189 225 130 10 202 137 121 152 198 25 49 165 180 228 56 30 74 18 14 6 115 31 168 242 206 90 238 139 44 103 60 16 21 190 229 209 68 41 171 181 39 74 73 181 96 18 234 95 70 75 174 84 101 16 44 202 249 80 ...
output:
4 255 0 0 255.000000000000 255 255 0 123.734177215190 255 255 255 14.913733827906 0 0 0 5.623273068241 4 0 255 0 255.000000000000 0 255 255 1.045081967213 255 255 255 1.468923398243 0 0 0 10.000416484455 4 0 255 0 255.000000000000 0 255 255 134.210526315789 255 255 255 135.684205687129 0 0 0 96.5955...
result:
ok ok (10000 test cases)
Test #3:
score: 0
Accepted
time: 19ms
memory: 3856kb
input:
10000 90 173 87 39 251 59 39 43 150 106 29 130 52 55 180 236 225 70 171 15 48 92 133 240 182 226 10 126 139 105 196 7 204 32 131 193 27 96 218 67 29 33 159 9 251 130 111 243 226 69 39 198 131 80 108 169 147 45 36 170 76 138 251 55 235 186 224 165 48 51 133 173 225 14 226 234 70 139 178 92 174 138 24...
output:
4 0 255 0 255.000000000000 255 255 0 8.895348837209 255 255 255 178.219409773690 0 0 0 101.214013462069 4 0 255 0 255.000000000000 0 255 255 24.056603773585 255 255 255 53.455585745924 0 0 0 4.155758539953 4 0 0 255 255.000000000000 0 255 255 9.189189189189 255 255 255 92.088445195341 0 0 0 112.5890...
result:
ok ok (10000 test cases)
Test #4:
score: 0
Accepted
time: 19ms
memory: 3964kb
input:
10000 186 217 161 76 0 116 246 159 161 32 245 65 206 120 71 217 76 204 109 255 245 157 59 192 55 35 87 27 147 199 190 134 31 169 64 105 5 27 255 161 2 35 244 255 232 253 106 199 28 151 129 50 24 20 172 236 234 74 51 150 179 68 178 69 42 192 152 1 23 177 169 71 216 190 125 136 223 193 255 168 49 74 2...
output:
4 0 255 0 255.000000000000 255 255 0 113.839285714286 255 255 255 216.247590735133 0 0 0 57.443660484332 4 0 0 255 255.000000000000 255 0 255 167.068965517241 255 255 255 0.000000000000 0 0 0 166.176281341172 4 255 0 0 255.000000000000 255 0 255 5.862068965517 255 255 255 230.422960514099 0 0 0 12.2...
result:
ok ok (10000 test cases)
Test #5:
score: 0
Accepted
time: 19ms
memory: 3944kb
input:
10000 26 6 234 114 6 172 198 19 173 214 204 1 104 186 218 199 182 82 47 240 186 223 240 143 184 99 164 184 155 37 185 4 114 49 253 17 239 214 37 0 231 38 73 245 212 121 102 155 86 234 219 157 173 216 236 46 65 103 67 130 27 253 105 83 105 197 81 93 254 47 206 225 207 110 24 38 119 248 76 243 180 10 ...
output:
4 0 0 255 255.000000000000 255 0 255 22.368421052632 255 255 255 8.850517375070 0 0 0 21.136092005687 4 0 0 255 255.000000000000 255 0 255 165.903614457831 255 255 255 9.422684253211 0 0 0 99.617580024134 4 255 0 0 255.000000000000 255 0 255 219.385474860335 255 255 255 24.707200468541 0 0 0 75.8897...
result:
ok ok (10000 test cases)
Test #6:
score: 0
Accepted
time: 20ms
memory: 3860kb
input:
10000 122 50 52 152 12 229 149 135 184 140 164 193 2 251 109 180 33 217 241 225 126 33 165 94 57 163 242 85 164 132 179 131 197 185 186 185 216 145 74 95 203 40 158 236 193 245 97 111 144 61 52 9 67 157 44 113 152 132 82 110 130 182 33 96 168 202 10 184 228 173 243 124 198 29 180 196 15 47 153 63 54...
output:
4 255 0 0 255.000000000000 255 0 255 7.083333333333 255 255 255 145.758629495058 0 0 0 154.511269265445 4 0 0 255 255.000000000000 255 0 255 164.516129032258 255 255 255 14.178747897563 0 0 0 31.235916221485 4 0 0 255 255.000000000000 255 0 255 72.857142857143 255 255 255 229.918514998403 0 0 0 105....
result:
ok ok (10000 test cases)
Test #7:
score: 0
Accepted
time: 19ms
memory: 3980kb
input:
10000 218 94 126 189 17 30 100 251 196 67 123 128 157 60 0 161 139 95 179 210 67 98 91 45 186 227 63 242 172 226 173 1 24 66 118 98 194 75 112 189 176 43 243 226 174 112 93 67 202 143 142 117 216 97 108 179 239 161 97 91 233 111 216 110 231 208 195 20 203 43 24 22 189 205 79 98 167 102 230 139 185 1...
output:
4 255 0 0 255.000000000000 255 0 255 65.806451612903 255 255 255 136.912462208607 0 0 0 45.616512063956 4 255 0 0 255.000000000000 255 0 255 19.273255813953 255 255 255 31.235361925430 0 0 0 67.089438016529 4 0 255 0 255.000000000000 0 255 255 162.119205298013 255 255 255 108.122999452029 0 0 0 5.31...
result:
ok ok (10000 test cases)
Test #8:
score: 0
Accepted
time: 19ms
memory: 3852kb
input:
10000 58 139 199 227 23 87 52 111 207 249 83 64 55 125 147 142 246 229 118 194 7 164 16 252 59 36 140 143 180 64 167 127 108 202 51 10 172 6 150 28 149 45 72 217 154 236 88 23 4 226 232 225 109 37 172 245 69 190 112 71 81 40 143 124 38 213 124 112 178 169 61 176 180 125 234 1 63 157 51 215 59 75 216...
output:
4 0 0 255 255.000000000000 0 255 255 146.489361702128 255 255 255 80.770780434563 0 0 0 70.231213307499 4 255 0 0 255.000000000000 255 0 255 80.000000000000 255 255 255 31.336065477217 0 0 0 30.119908889084 4 0 0 255 255.000000000000 0 255 255 97.064516129032 255 255 255 75.349178302113 0 0 0 55.784...
result:
ok ok (10000 test cases)
Test #9:
score: 0
Accepted
time: 19ms
memory: 3904kb
input:
10000 154 183 17 8 28 144 3 227 218 175 43 0 209 191 38 123 96 107 56 179 204 230 197 204 188 100 217 43 189 158 161 254 191 83 240 178 150 193 187 123 122 48 157 207 135 103 84 235 62 53 66 77 2 234 237 56 156 219 127 51 184 225 70 138 102 218 53 203 153 39 98 75 171 45 134 159 215 212 128 35 190 1...
output:
4 0 255 0 255.000000000000 255 255 0 210.451807228916 255 255 255 24.047290772161 0 0 0 94.339304252225 4 0 0 255 255.000000000000 0 255 255 37.500000000000 255 255 255 18.619919142920 0 0 0 113.246933978610 4 0 255 0 255.000000000000 0 255 255 244.754464285714 255 255 255 3.372763116665 0 0 0 38.82...
result:
ok ok (10000 test cases)
Test #10:
score: 0
Accepted
time: 19ms
memory: 3904kb
input:
10000 250 227 91 46 34 201 210 87 230 102 2 191 107 0 185 104 203 241 250 164 144 40 123 155 61 164 38 200 197 253 155 124 18 219 173 90 127 124 225 217 94 50 242 198 116 227 79 191 120 136 155 184 151 174 45 122 243 248 142 31 31 154 253 152 165 224 238 39 128 165 134 229 162 220 33 61 111 11 205 1...
output:
4 255 0 0 255.000000000000 255 255 0 218.113207547170 255 255 255 93.786092548796 0 0 0 6.994569321981 4 0 0 255 255.000000000000 255 0 255 18.323353293413 255 255 255 58.850318187549 0 0 0 56.144111740561 4 0 0 255 255.000000000000 255 0 255 219.335664335664 255 255 255 97.395339151834 0 0 0 35.149...
result:
ok ok (10000 test cases)
Test #11:
score: 0
Accepted
time: 19ms
memory: 3908kb
input:
10000 208 135 142 248 171 248 162 65 32 9 162 63 91 20 90 188 236 117 62 200 71 14 228 53 68 196 133 27 159 255 129 86 121 46 216 3 213 65 177 7 28 45 215 136 153 108 54 113 254 122 99 243 222 89 18 255 48 14 157 204 210 33 132 87 4 33 231 222 233 30 14 100 10 45 226 49 210 232 113 79 18 235 109 14 ...
output:
4 255 0 0 255.000000000000 255 0 255 24.452054794521 255 255 255 223.119519700906 0 0 0 64.568484903926 4 255 0 0 255.000000000000 255 0 255 255.000000000000 255 255 255 175.826612903226 0 0 0 11.013455049056 4 255 0 0 255.000000000000 255 255 0 64.730769230769 255 255 255 62.846914750940 0 0 0 101....
result:
ok ok (10000 test cases)
Test #12:
score: 0
Accepted
time: 19ms
memory: 3952kb
input:
10000 119 133 74 50 106 117 59 203 94 72 223 194 202 156 197 61 81 108 77 80 107 240 230 250 53 54 66 133 197 44 33 113 2 83 54 163 206 241 33 41 83 202 182 57 124 37 155 241 186 245 218 153 80 29 47 83 212 41 32 94 107 89 186 58 161 214 114 106 34 17 89 16 19 117 170 169 115 74 55 143 33 6 182 196 ...
output:
4 0 255 0 255.000000000000 255 255 0 194.491525423729 255 255 255 145.819317929635 0 0 0 177.220482883313 4 0 0 255 255.000000000000 0 255 255 213.134328358209 255 255 255 110.433282948739 0 0 0 195.328917291601 4 0 255 0 255.000000000000 0 255 255 61.979166666667 255 255 255 92.951342969230 0 0 0 5...
result:
ok ok (10000 test cases)
Test #13:
score: 0
Accepted
time: 20ms
memory: 3908kb
input:
10000 170 100 234 20 253 12 243 196 46 206 129 235 149 5 166 232 179 7 149 75 45 98 197 156 206 22 133 230 176 54 159 228 135 170 92 118 90 61 180 9 26 18 21 65 122 40 143 87 125 192 199 176 35 144 44 85 243 153 238 203 227 9 212 200 74 226 253 135 20 139 117 222 230 43 212 42 201 224 22 222 152 191...
output:
4 0 0 255 255.000000000000 255 0 255 133.208955223881 255 255 255 120.765675956522 0 0 0 27.464471101999 4 0 255 0 255.000000000000 255 255 0 8.464730290456 255 255 255 16.823217244241 0 0 0 2.008480823763 4 255 0 0 255.000000000000 255 255 0 194.162436548223 255 255 255 49.626397828324 0 0 0 15.583...
result:
ok ok (10000 test cases)
Test #14:
score: 0
Accepted
time: 19ms
memory: 3856kb
input:
10000 67 216 241 14 40 250 28 215 219 200 241 181 3 167 13 227 218 113 85 72 151 116 20 162 202 252 17 54 184 231 49 90 219 117 173 19 37 53 223 10 195 119 118 128 187 46 208 215 54 85 104 71 99 34 234 95 0 44 223 10 14 248 47 123 70 75 245 118 231 131 187 137 34 62 21 4 118 233 40 183 96 242 97 190...
output:
4 0 0 255 255.000000000000 0 255 255 218.362068965517 255 255 255 71.620105975103 0 0 0 19.198796614090 4 0 0 255 255.000000000000 0 255 255 28.093220338983 255 255 255 19.114932627494 0 0 0 5.071331186188 4 0 0 255 255.000000000000 0 255 255 249.659685863874 255 255 255 32.609888469921 0 0 0 50.658...
result:
ok ok (10000 test cases)
Test #15:
score: 0
Accepted
time: 18ms
memory: 3928kb
input:
10000 252 245 224 4 171 9 240 190 208 69 15 254 4 230 90 0 255 17 6 26 58 150 187 237 239 242 146 255 227 231 232 117 26 44 255 111 183 1 9 121 85 207 15 245 120 247 181 40 1 255 164 244 139 255 131 248 27 161 24 241 63 44 16 207 36 251 15 227 163 49 7 180 27 7 23 61 254 235 14 8 11 200 7 3 26 254 3...
output:
4 255 0 0 255.000000000000 255 255 0 191.250000000000 255 255 255 233.642652118334 0 0 0 4.961658548868 4 0 255 0 255.000000000000 0 255 255 7.634730538922 255 255 255 8.310337049509 0 0 0 84.139209567490 4 255 0 0 255.000000000000 255 0 255 91.800000000000 255 255 255 239.679276586442 0 0 0 23.1304...
result:
ok ok (10000 test cases)
Test #16:
score: 0
Accepted
time: 17ms
memory: 3852kb
input:
10000 10 7 240 232 252 180 5 169 10 1 40 6 252 2 242 245 8 5 249 17 249 255 2 233 12 3 1 2 6 253 252 254 2 251 245 6 254 4 252 10 244 245 254 218 52 255 8 4 20 112 248 253 0 254 250 234 1 226 245 216 11 6 2 245 139 0 8 28 233 1 11 24 246 250 253 9 124 17 255 26 1 14 251 46 2 14 248 233 1 44 12 255 1...
output:
4 0 0 255 255.000000000000 255 0 255 3.283261802575 255 255 255 10.450718923095 0 0 0 15.019388511188 4 0 255 0 255.000000000000 255 255 0 184.166666666667 255 255 255 189.039409981298 0 0 0 4.606512199976 4 0 255 0 255.000000000000 0 255 255 7.774390243902 255 255 255 10.507978720215 0 0 0 86.18798...
result:
ok ok (10000 test cases)
Test #17:
score: 0
Accepted
time: 16ms
memory: 3924kb
input:
10000 0 3 254 9 1 2 250 254 0 4 1 65 212 3 253 253 255 254 252 1 255 255 230 11 253 215 255 113 12 16 252 253 0 255 254 254 254 255 252 0 32 254 255 36 252 10 1 243 3 46 11 99 3 255 250 0 248 11 5 3 253 254 255 23 2 1 0 253 4 255 255 248 255 237 250 7 13 1 251 251 246 0 0 4 0 2 1 254 254 0 189 3 0 2...
output:
4 0 0 255 255.000000000000 0 255 255 3.011811023622 255 255 255 0.000000000000 0 0 0 1.000069747707 4 255 0 0 255.000000000000 255 0 255 31.875000000000 255 255 255 37.648433086769 0 0 0 253.478905543549 4 0 255 0 255.000000000000 255 255 0 250.984251968504 255 255 255 0.000000000000 0 0 0 1.4031222...
result:
ok ok (10000 test cases)
Test #18:
score: 0
Accepted
time: 7ms
memory: 3848kb
input:
10000 0 253 255 255 252 2 255 0 255 250 253 255 253 0 255 252 251 236 8 255 0 247 254 254 2 255 255 255 255 252 0 0 4 6 250 0 7 32 0 0 2 255 255 9 255 3 255 1 255 255 242 254 0 0 0 0 254 0 255 255 1 0 9 255 255 2 0 255 0 0 0 255 254 9 1 253 255 254 252 0 255 0 0 255 254 0 252 255 247 0 2 250 255 255...
output:
4 0 0 255 255.000000000000 0 255 255 253.000000000000 255 255 255 0.000000000000 0 0 0 0.000000000000 4 255 0 0 255.000000000000 255 255 0 251.976284584980 255 255 255 2.000140600285 0 0 0 0.000000000000 4 255 0 0 255.000000000000 255 0 255 255.000000000000 255 255 255 0.000000000000 0 0 0 0.0000000...
result:
ok ok (10000 test cases)
Test #19:
score: 0
Accepted
time: 13ms
memory: 3924kb
input:
10000 0 0 0 255 0 255 0 255 255 255 255 1 0 0 0 0 255 1 255 0 254 0 255 0 0 203 255 0 2 0 255 0 255 255 254 0 255 0 255 255 255 228 0 255 255 0 255 255 0 254 0 253 0 0 242 0 0 255 0 0 255 252 0 0 0 0 0 0 0 255 255 255 0 0 255 255 255 0 4 255 0 0 1 0 0 0 255 0 253 253 0 255 255 0 0 255 255 0 0 1 255 ...
output:
0 4 255 0 0 255.000000000000 255 0 255 255.000000000000 255 255 255 0.000000000000 0 0 0 0.000000000000 4 0 255 0 255.000000000000 0 255 255 255.000000000000 255 255 255 0.000000000000 0 0 0 0.000000000000 4 255 0 0 255.000000000000 255 255 0 255.000000000000 255 255 255 1.000000000000 0 0 0 0.00000...
result:
ok ok (10000 test cases)
Test #20:
score: 0
Accepted
time: 11ms
memory: 3916kb
input:
10000 0 0 0 0 255 255 255 0 255 255 255 0 255 255 255 255 0 0 255 255 255 0 0 255 0 0 0 0 0 255 255 255 0 0 0 255 255 0 0 0 0 0 255 255 0 0 0 255 0 0 0 255 255 0 0 0 255 0 255 0 255 0 255 0 255 255 0 255 0 0 255 0 1 0 255 255 0 254 255 0 255 255 255 255 0 255 255 255 0 255 255 0 255 0 255 255 255 25...
output:
0 4 0 255 0 255.000000000000 0 255 255 255.000000000000 255 255 255 0.000000000000 0 0 0 0.000000000000 4 255 0 0 255.000000000000 255 0 255 255.000000000000 255 255 255 0.000000000000 0 0 0 0.000000000000 4 255 0 0 255.000000000000 255 255 0 255.000000000000 255 255 255 0.000000000000 0 0 0 0.00000...
result:
ok ok (10000 test cases)