結果
| 問題 | 
                            No.1365 [Cherry 1st Tune] Whose Fault?
                             | 
                    
| コンテスト | |
| ユーザー | 
                             Nachia
                         | 
                    
| 提出日時 | 2021-02-06 17:08:31 | 
| 言語 | C++17  (gcc 13.3.0 + boost 1.87.0)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 231 ms / 2,000 ms | 
| コード長 | 571 bytes | 
| コンパイル時間 | 2,131 ms | 
| コンパイル使用メモリ | 197,176 KB | 
| 最終ジャッジ日時 | 2025-01-18 13:37:12 | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge4 / judge5 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 46 | 
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:4:19: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
    4 | #define S(a) scanf("%d",&a);
      |              ~~~~~^~~~~~~~~
main.cpp:12:1: note: in expansion of macro ‘S’
   12 | S(N)D G(N);R S(A[i]);R {S(u);A[i]-=u;}R {S(u);P[i]=1./u;ans+=f(i);}S(N)
      | ^
main.cpp:4:19: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
    4 | #define S(a) scanf("%d",&a);
      |              ~~~~~^~~~~~~~~
main.cpp:12:14: note: in expansion of macro ‘S’
   12 | S(N)D G(N);R S(A[i]);R {S(u);A[i]-=u;}R {S(u);P[i]=1./u;ans+=f(i);}S(N)
      |              ^
main.cpp:4:19: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
    4 | #define S(a) scanf("%d",&a);
      |              ~~~~~^~~~~~~~~
main.cpp:12:25: note: in expansion of macro ‘S’
   12 | S(N)D G(N);R S(A[i]);R {S(u);A[i]-=u;}R {S(u);P[i]=1./u;ans+=f(i);}S(N)
      |                         ^
main.cpp:4:19: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
    4 | #define S(a) scanf("%d",&a);
      |              ~~~~~^~~~~~~~~
main.cpp:12:42: note: in expansion of macro ‘S’
   12 | S(N)D G(N);R S(A[i]);R {S(u);A[i]-=u;}R {S(u);P[i]=1./u;ans+=f(i);}S(N)
      |                                          ^
main.cpp:4:19: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
    4 | #define S(a) scanf("%d",&a);
      |              ~~~~~^~~~~~~~~
main.cpp:12:68: note: in expansion of macro ‘S’
   12 | S(N)D G(N);R S(A[i]);R {S(u);A[i]-=u;}R {S(u);P[i]=1./u;ans+=f(i);}S(N)
      |                                                             
            
            ソースコード
#include<bits/stdc++.h>
using namespace std;
#define I int
#define S(a) scanf("%d",&a);
#define R for(I i=0;i<(N);i++)
struct D{vector<I> V;D(I n){V.assign(n,-1);}I r(I a){return(V[a]<0)?a:(V[a]=r(V[a]));}I u(I a,I b){a=r(a);b=r(b);return(a==b)?-1:(V[b]=a);}};
I N,A[100000],u,v,g;
double P[100000],ans=0.0;
double f(I i){return A[i]*A[i]/P[i];}
I main(){
S(N)D G(N);R S(A[i]);R {S(u);A[i]-=u;}R {S(u);P[i]=1./u;ans+=f(i);}S(N)
R{S(u)S(v)u=G.r(u-1);v=G.r(v-1);if(u!=v){g=G.u(u,v);ans-=f(u)+f(v);A[g]+=A[u+v-g];P[g]+=P[u+v-g];ans+=f(g);}printf("%.4f\n",ans);}
return 0;}
            
            
            
        
            
Nachia