結果

問題 No.439 チワワのなる木
ユーザー smiken_61smiken_61
提出日時 2016-11-13 23:59:18
言語 C++11
(gcc 11.4.0)
結果
AC  
実行時間 139 ms / 5,000 ms
コード長 3,839 bytes
コンパイル時間 1,224 ms
コンパイル使用メモリ 166,104 KB
実行使用メモリ 36,224 KB
最終ジャッジ日時 2024-11-25 22:07:25
合計ジャッジ時間 3,852 ms
ジャッジサーバーID
(参考情報)
judge5 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 7 ms
12,672 KB
testcase_01 AC 7 ms
12,672 KB
testcase_02 AC 7 ms
12,544 KB
testcase_03 AC 7 ms
12,672 KB
testcase_04 AC 8 ms
12,672 KB
testcase_05 AC 8 ms
12,672 KB
testcase_06 AC 8 ms
12,672 KB
testcase_07 AC 8 ms
12,672 KB
testcase_08 AC 7 ms
12,672 KB
testcase_09 AC 7 ms
12,800 KB
testcase_10 AC 8 ms
12,800 KB
testcase_11 AC 7 ms
12,672 KB
testcase_12 AC 7 ms
12,672 KB
testcase_13 AC 7 ms
12,928 KB
testcase_14 AC 7 ms
12,800 KB
testcase_15 AC 8 ms
12,800 KB
testcase_16 AC 9 ms
12,928 KB
testcase_17 AC 9 ms
13,056 KB
testcase_18 AC 86 ms
19,840 KB
testcase_19 AC 72 ms
18,688 KB
testcase_20 AC 118 ms
22,016 KB
testcase_21 AC 31 ms
15,232 KB
testcase_22 AC 30 ms
15,232 KB
testcase_23 AC 133 ms
23,680 KB
testcase_24 AC 139 ms
33,408 KB
testcase_25 AC 78 ms
19,440 KB
testcase_26 AC 70 ms
20,264 KB
testcase_27 AC 97 ms
36,224 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

            #include <bits/stdc++.h>
            #include<iostream>
            #include<cstdio>
            #include<vector>
            #include<queue>
            #include<map>
            #include<cstring>
            #include<string>
            #include <math.h>
            #include<algorithm>
        //    #include <boost/multiprecision/cpp_int.hpp>
            #include<functional>
          #define int long long
            #define inf  1000000007
            #define pa pair<int,int>
    #define ll long long
            #define pal pair<ll,ll>
            #define ppa pair<int,pa>
            #define  mp make_pair
            #define  pb push_back
            #define EPS (1e-10)
            #define equals(a,b) (fabs((a)-(b))<EPS)
     
            using namespace std;
     
            class Point{
            	public:
            	double x,y;
            	Point(double x=0,double y=0):x(x),y(y) {}
            	Point operator + (Point p) {return Point(x+p.x,y+p.y);}
            	Point operator - (Point p) {return Point(x-p.x,y-p.y);}
            	Point operator * (double a) {return Point(x*a,y*a);}
            	Point operator / (double a) {return Point(x/a,y/a);}
            	double absv() {return sqrt(norm());}
            	double norm() {return x*x+y*y;}
            	bool operator < (const Point &p) const{
            		return x != p.x ? x<p.x: y<p.y;
            	}
            	bool operator == (const Point &p) const{
            		return fabs(x-p.x)<EPS && fabs(y-p.y)<EPS;
            	}
            };
            typedef Point Vector;
     
            struct Segment{
            Point p1,p2;
            };
     
        double hen(Vector a){
        if(fabs(a.x)<EPS && a.y>0) return acos(0);
        else if(fabs(a.x)<EPS && a.y<0) return 3*acos(0);
        else if(fabs(a.y)<EPS && a.x<0) return 2*acos(0);
        else if(fabs(a.y)<EPS && a.x>0) return 0.0;
        else if(a.y>0) return acos(a.x/a.absv());
        else return 2*acos(0)+acos(-a.x/a.absv());
     
        }
     
int gcd(int v,int b){
	if(v>b) return gcd(b,v);
	if(v==b) return b;
	if(b%v==0) return v;
	return gcd(v,b%v);
}
            double dot(Vector a,Vector b){
            	return a.x*b.x+a.y*b.y;
            }
            double cross(Vector a,Vector b){
            	return a.x*b.y-a.y*b.x;
            }
        
            //----------------kokomade temple------------
int x,y,n,m;
string s;
int keta[10]={0};


vector<int> G[100002];
vector<int> G2[100002];
vector<int> cc[100002];
vector<int> ww[100002];

void saikisaiki(int u,int mae){

	for(int i=0;i<G[u].size();i++){
		if(G[u][i]==mae) continue;
		G2[u].push_back(G[u][i]);
		saikisaiki(G[u][i],u);
	}
	
}

void make_root(int root){
saikisaiki(root,-1);
return ;
}


pa dfs(int r){
	
	if(G2[r].size()==0){
		if(s[r]=='c') return mp(1,0);
		else return mp(0,1);
	}
	pa z=mp(0,0);
	if(s[r]=='c') z.first++;
		else z.second ++ ;
	
	for(int i=0;i<G2[r].size();i++){
		pa zz=dfs(G2[r][i]);
		z.first += zz.first;
		z.second += zz.second;
		cc[r].pb(zz.first);
		ww[r].pb(zz.second);
	}
	
	return z;
}

    signed main(){
    	cin>>n;
cin>>s;
    s = "q"+s;
    	for(int i=0;i<n-1;i++){
    		int zzz,zz;
    		cin>>zz>>zzz;
    		G[zz].pb(zzz);
    		G[zzz].pb(zz);
    		
    	}
    	make_root(1);
    	
    	pa z=dfs(1);
    	int cnum=z.first,wnum=z.second;
  //  	cout<<z.first<<" "<<z.second<<endl;
    	int ans=0;
    	for(int i=1;i<=n;i++){
    		if(s[i]=='c') continue;
    		if(G2[i].size()==0) continue;
    		int cx=0,wx=0;
    		for(int j=0;j<G2[i].size();j++){
    			cx += cc[i][j];
    			wx += ww[i][j];
    			ans += cc[i][j] * (wnum-ww[i][j]-1);
    			
    		}
    		if(i!=1){
    			ans += (cnum-cx)*(wx);
    //			cout<<" "<<cnum-cx<<" "<<wx<<endl;
    		}
    		
    	}
    	cout<<ans<<endl;
    //	printf("%.10f\n",ans);
    	return 0;
    }
0