제출 #383513

#제출 시각아이디문제언어결과실행 시간메모리
383513ParsaAlizadeh미술 수업 (IOI13_artclass)C++17
29 / 100
73 ms3948 KiB
#include "artclass.h" #include <bits/stdc++.h> using namespace std; typedef long long ll; typedef pair<ll, ll> pll; typedef pair<int, int> pii; #define all(x) x.begin(), x.end() #define kill(x) return cout << x << endl, 0 #define X first #define Y second #define endl '\n' #define debug(x) #x << " : " << x << " / " constexpr ll pw(ll a, ll b, ll mod) { return (!b ? 1 : b & 1 ? a * pw(a * a % mod, b / 2, mod) % mod : pw(a * a % mod, b / 2, mod)); } constexpr int N = 1e5 + 10; struct HSV { double h, s, v; HSV(double r, double g, double b) { r /= 255; g /= 255; b /= 255; double cmax = max({r, g, b}), cmin = min({r ,g, b}), d = cmax - cmin; v = cmax * 100; h = ( cmax == cmin ? 0 : cmax == r ? (double) 60 * fmod((g - b) / d, 6) : cmax == g ? (double) 60 * ((b - r) / d + 2) : (double) 60 * ((r - g) / d + 4) ); s = ( cmax == 0 ? 0 : d * 100 / cmax ); } }; double twh, tgr, tbl, trd; int style(int H, int W, int R[500][500], int G[500][500], int B[500][500]) { for (int i = 0; i < H; i++) { for (int j = 0; j < W; j++) { HSV cur = {R[i][j], G[i][j], B[i][j]}; if (35 <= cur.h && cur.h <= 200 && cur.s >= 40 && cur.v >= 40) tgr++; if ((cur.h <= 25 || 340 <= cur.h) && cur.s >= 30 && cur.v >= 30) trd++; if (cur.v <= 20) tbl++; if (cur.v >= 30 && cur.s <= 20) twh++; } } twh = twh * 100 / W / H; tgr = tgr * 100 / W / H; tbl = tbl * 100 / W / H; trd = trd * 100 / W / H; if (trd >= 18) return 4; if (tgr >= 24) return 2; if (twh >= 60) return 1; return 3; /* if (trd >= 19) return 4; if (tgr >= 40) return 2; if (tbl >= 21) return 3; return 1; */ cout << setprecision(2) << fixed; cout << debug(tgr) << debug(trd) << debug(tbl) << debug(twh) << endl; return 1; }

컴파일 시 표준 에러 (stderr) 메시지

artclass.cpp: In function 'int style(int, int, int (*)[500], int (*)[500], int (*)[500])':
artclass.cpp:49:30: warning: narrowing conversion of '(*(R + ((sizetype)(((long unsigned int)i) * 2000))))[j]' from 'int' to 'double' [-Wnarrowing]
   49 |             HSV cur = {R[i][j], G[i][j], B[i][j]};
      |                        ~~~~~~^
artclass.cpp:49:39: warning: narrowing conversion of '(*(G + ((sizetype)(((long unsigned int)i) * 2000))))[j]' from 'int' to 'double' [-Wnarrowing]
   49 |             HSV cur = {R[i][j], G[i][j], B[i][j]};
      |                                 ~~~~~~^
artclass.cpp:49:48: warning: narrowing conversion of '(*(B + ((sizetype)(((long unsigned int)i) * 2000))))[j]' from 'int' to 'double' [-Wnarrowing]
   49 |             HSV cur = {R[i][j], G[i][j], B[i][j]};
      |                                          ~~~~~~^
#Verdict Execution timeMemoryGrader output
Fetching results...