阅读 15

C语言系统化精讲 重塑你的编程思想 打造坚实的开发基础

download:C语言系统化精讲 重塑你的编程思想 打造坚实的开发基础

修炼内功最强语言,训练编程思想最有效语言,圣经般存在的语言,2020 TIOBE排行冠军语言——这些说的,都是C语言。每个优秀开发者都应该精通C语言,这门课程就是为所有没学过、没学好C语言的你专属打造,多种编程语言技术专家bennyhuo独家分享,带你系统、高效、轻松啃透C语言这个硬骨头!

适合人群

希望获得更深层次进阶语言的开发者

希望夯实语言基础的开发者

希望精雕细琢掌握多门语言的开发者

有面试/跳槽/晋升需求的开发者和在校生

技术储备要求

零门槛,有计算机基础、操作系统、编程基础和经验更佳

![]()![]()```
1 #include<bits/stdc++.h>
2 using namespace std;
3 const int maxn=3e5+10;
4 const int mod=1e9+7;
5 #define ll long long
6 #define pi pair<int,int>
7 #define fi first
8 #define sc second
9 #define pb push_back
10 int cnt[maxn][2];
11 int a[maxn];
12 vectorE[maxn];
13 int ans,n;
14 int cntr,cntb;
15
16 void dfs(int u,int fa)
17 {
18 if(a[u]==1) cnt[u][1]++;
19 if(a[u]==2) cnt[u][0]++;
20 for(auto &v:E[u])
21 {
22 if(v==fa) continue;
23 dfs(v,u);
24 cnt[u][0]+=cnt[v][0];
25 cnt[u][1]+=cnt[v][1];
26 if(cnt[v][1]==cntr&&cnt[v][0]==0)
27 ans++;
28 if(cnt[v][0]==cntb&&cnt[v][1]==0)
29 ans++;
30 }
31 }
32
33
34 int main()
35 {
36 ios::sync_with_stdio(0);
37 cin.tie(0);
38 cin>>n;
39 for(int i=1;i<=n;i++) cin>>a[i],cntr+=a[i]==1,cntb+=a[i]==2;
40 for(int i=1;i<n;i++)
41 {
42 int x,y;
43 cin>>x>>y;
44 E[x].pb(y);
45 E[y].pb(x);
46 }
47 if(cntr&&cntb)
48 dfs(1,0);
49 else
50 ans=n-1;
51 cout<<ans<<'\n';
52
53
54
55
56
57 }

文章分类
后端
文章标签