-
个人简介
怒斥一,二名
Welcome to PhigrOS , Friday night Funkin and minecraft
-O2 -std=c++14 -static
我去!那么多模板呢? 哦~在这儿!
快点击下方链接去看stone9070分享的算法模版吧!
快速传送~http://xx.ncyzedu.cn:4326/pdfbrowser/web/viewer.html?file=/downloads/knowledge_list/算法模板.pdf
堆(可用于树)
priority_queue<int>q;//默认大顶堆 priority_queue<int,vector<int>,less<int>>q;//小顶堆 priority_queue<int,vector<int>,greater<int>>q;//大顶堆 q.push(x) //入堆 q.pop() //出堆 q.top() //堆顶 q.size() //元素数量
树形背包(理解版)
#include<iostream> #include<vector> using namespace std; struct Thing//定义一个物品结构体包括物品属性体积和价值 { int vi; int wi; }; /*定义以下全局变量*/ vector< vector<int> >tree;//定义一个二维数组存储各个节点的子节点信息 vector<Thing>things; //定义物品数组存储物品的信息 int N,V;//定义物品的数量和背包的体积 int ans[110][110]; //定义二维数组存储答案ans[i][j]表示在选节点i且体积不超过j的前提下所能得到的最大价值 void dfs(int Node) {/*此函数的功能是在得到一个节点后我们要把在选这个节点的情况下 的每一体积下的最大值都求出来并存入ans数组中 */ if(things[Node].vi <= V)//先判断背包能否放下该节点代表的物品如果可以则进入判断 { if(tree[Node].size()==0||things[Node].vi == V) {/*判断如果该节点没有子节点或其代表的物品体积恰好等于背包体积 在这两种情况下都不必再去考虑该节点的子节点怎么选择直接赋值*/ for(int i=things[Node].vi;i<=V;i++) {/*将大于或等于该物品的各个体积全赋为该物品的价值 并将其他体积全赋值为0这里因为ans为全局变量所以 各点本身就以赋初值为0在这里就不再进行这一操作*/ ans[Node][i]=things[Node].wi; } } else//否则我们需要考虑其子节点的选择情况 { for(int k=0;k<tree[Node].size();k++)//我们要遍历各个子节点 { dfs(tree[Node][k]);//首先我们求出选这个子节点的情况下各体积下的最优解 for(int i=V-things[Node].vi;i>=0;i--) {/*我们开始求选当前节点的情况下各体积下的最优解 我们的体积从V-things[Node].vi开始到0因为我们 确定了选当前物品所以要为他留出空间,体积从大 到小是因为和01背包一样子节点的每种体积至多可以选一遍*/ for(int j=0;j<=i;j++)//当前0到i这个范围就是这个子节点以下所能占用的体积我们要从这些体积中选出最优的那个体积 ans[Node][i] = max(ans[Node][i],ans[Node][i-j]+ans[tree[Node][k]][j]); /*状态转移我们要用在不选、以及分别从这个子节点以下选总体积为1、2……i的物品中 选择一个最佳决策,即比较当前价值和选不同体积下的价值分别作比较*/ } } for(int i=V;i>=things[Node].vi;i--)//最后我们要将我们的根节点的价值加入即开始我们为之空出的体积 {//在这个体积以上的全部加上这个节点代表的物品的价值 ans[Node][i] = ans[Node][i-things[Node].vi] + things[Node].wi; } for(int i = 0;i < things[Node].vi;i++ ) {/*这个体积以下的代表这个节点不能选这个节点不能选那么他所有的子节点也不能选所以全部赋初值为0 这里需要赋值是因为我们在上面的求大体积最优解的时候用到了这块体积我们已经为他们赋上值了 它们已经不是0了所以这里的赋0不能省*/ ans[Node][i]=0; } } } } int main() { int root; //定义一个变量一会储存根节点 cin>>N>>V; //输入物品数和背包体积 tree.resize(N);//开辟空间一个数组储存各节点的子节点信息从而储存整棵树的结点关系 for(int i=0;i<N;i++)//遍历输入物品信息 { int v,w,f; cin>>v>>w>>f; things.push_back({v,w});//将物品信息放入物品数组things if(f==-1)//检查该节点的父节点是哪一个如果它是父节点则记录它 { root=i; } else//如果不是父节点在在其父节点代表的一维数组中存入该节点 { tree[f-1].push_back(i);//我们的节点下标从0到n-1输入的父节点是1到n所以让输入的f减去1即我们要找的父节点 } } dfs(root);//从根节点调用递归函数 cout<<ans[root][V]<<endl;//输出最终结果 return 0; } //https://zhuanlan.zhihu.com/p/648341058
线段树
初段
//P1313 区间和 #include<bits/stdc++.h> using namespace std; #define lson l,m,rt<<1 #define rson m+1,r,rt<<1|1 const long long maxn=1e6+10; long long n,sum[maxn<<2],q; //依照题意非子节点赋值 void Pushup(long long rt){ sum[rt]=sum[rt<<1]+sum[rt<<1|1]; } //建树 void build(long long l,long long r,long long rt){//l区间左边界 ,r区间右边界 ,rt此时节点编号 //sum[rt] if(l==r){//判断-如果是叶子节点,赋值sum[rt] scanf("%lld",&sum[rt]); return;//因为是叶子节点,所以没有子节点 } long long m=(l+r)>>1;//中点 //lson:l,m,rt<<1,rson:l,m,rt<<1|1 build(lson);//建左子结点 build(rson);//建右子结点 Pushup(rt);//放入sum[rt]的值 } //依照题意更新 void update(long long L,long long R,long long v,long long l,long long r,long long rt){//L目标区间左边界,R标目区间右边界,v更新值 if(l==r){ sum[rt]+=v; return; } long long m=(l+r)>>1;//二分查找 --| if(L<=m)update(L,R,v,lson);// |左端 if(m<R)update(L,R,v,rson);// <-|右端 Pushup(rt);//更新此节点 } //依照题意查询 long long query(long long L,long long R,long long l,long long r,long long rt){//L目标区间左边界,R标目区间右边界,v更新值 if(L<=l&&r<=R){ return sum[rt]; } long long m=(l+r)>>1,res=0;//二分查找 if(L<=m)res+=query(L,R,lson);//左端 if(m<R)res+=query(L,R,rson);//右端 return res;//返回答案 } int main(){ scanf("%lld%lld",&n,&q); build(1,n,1);//从根节点rt=1开始建树 long long op,a,b; while(q--){ scanf("%lld%lld%lld",&op,&a,&b); if(op==1){ update(a,a,b,1,n,1); }else{ printf("%lld\n",query(a,b,1,n,1)); } } return 0; }
lazy优化
//P1313 区间和 #include<bits/stdc++.h> using namespace std; #define lson l,m,rt<<1 #define rson m+1,r,rt<<1|1 const long long maxn=1e6+10; long long n,sum[maxn<<2],lazy[maxn<<2],q; //依照题意非子节点赋值 void Pushup(long long rt){ sum[rt]=sum[rt<<1]+sum[rt<<1|1]; } //建树 void build(long long l,long long r,long long rt){//l区间左边界 ,r区间右边界 ,rt此时节点编号 if(l==r){//判断-如果是叶子节点,赋值sum[rt] scanf("%lld",&sum[rt]); return;//因为是叶子节点,所以没有子节点 } long long m=(l+r)>>1;//中点 //lson:l,m,rt<<1,rson:l,m,rt<<1|1 build(lson);//建左子结点 build(rson);//建右子结点 Pushup(rt);//放入sum[rt]的值 } //为sum[rt]标记并改变其值 void addlazy(long long l,long long r,long long rt,long long v){ lazy[rt]+=v;//其以下的叶子结点标记值位v sum[rt]+=v*(r-l+1);//其本身的值加上其以下的叶子结点所改变的总和(v*r-l+1) } //下放标记(lazy) void Pushdown(long long l,long long r,long long rt,long long m){ if(lazy[rt]==0) return; //lson:l,m,rt<<1,rson:l,m,rt<<1|1 addlazy(lson,lazy[rt]);//为左儿子标记并使其本身的值加上其以下的叶子结点所改变的总和 addlazy(rson,lazy[rt]);//为左儿子标记并使其本身的值加上其以下的叶子结点所改变的总和 lazy[rt]=0;//消除标记 } //依照题意更新(lazy) void update(long long L,long long R,long long v,long long l,long long r,long long rt){//L目标区间左边界,R标目区间右边界,v更新值 if(L<=l&&r<=R){//确定符合条件的区间 addlazy(l,r,rt,v);//在这一区间内在sum[rt]放下lazy标记,标记值为v return; } long long m=(l+r)>>1;//二分 Pushdown(l,r,rt,m); if(L<=m)update(L,R,v,lson); if(m<R)update(L,R,v,rson); Pushup(rt);//更新此节点 } //依照题意查询 long long query(long long L,long long R,long long l,long long r,long long rt){//L:目标区间左边界,R:标目区间右边界,v:更新值 if(L<=l&&r<=R){//如果现在的区间就在目标区间内 return sum[rt];//返回其值 } long long m=(l+r)>>1,res=0;//二分查找 Pushdown(l,r,rt,m); if(L<=m)res+=query(L,R,lson);//左端 if(m<R)res+=query(L,R,rson);//右端 Pushup(rt);//更新此节点,可要可不要 return res;//返回答案 } int main(){ scanf("%lld%lld",&n,&q); build(1,n,1);//从根节点rt=1开始建树 long long op,a,b; while(q--){ scanf("%lld%lld%lld",&op,&a,&b); if(op==1){ update(a,a,b,1,n,1); }else{ printf("%lld\n",query(a,b,1,n,1)); } } return 0; }
-
通过的题目
- P1
- P2
- P3
- P4
- P5
- P6
- P7
- P8
- P9
- P10
- P11
- P12
- P13
- P14
- P15
- P16
- P17
- P18
- P19
- P20
- P21
- P22
- P23
- P24
- P25
- P26
- P27
- P28
- P29
- P30
- P31
- P32
- P33
- P34
- P35
- P36
- P37
- P38
- P39
- P40
- P41
- P42
- P43
- P44
- P45
- P46
- P47
- P48
- P49
- P50
- P51
- P52
- P53
- P54
- P55
- P56
- P57
- P58
- P59
- P60
- P61
- P62
- P63
- P64
- P65
- P66
- P67
- P68
- P69
- P70
- P71
- P72
- P73
- P74
- P75
- P76
- P77
- P78
- P79
- P80
- P81
- P82
- P83
- P84
- P85
- P86
- P87
- P88
- P89
- P90
- P91
- P92
- P93
- P94
- P95
- P96
- P98
- P99
- P100
- P101
- P102
- P103
- P104
- P105
- P106
- P107
- P108
- P109
- P110
- P111
- P113
- P114
- P115
- P116
- P117
- P118
- P119
- P120
- P121
- P122
- P123
- P124
- P125
- P127
- P128
- P129
- P130
- P131
- P132
- P133
- P134
- P136
- P137
- P139
- P141
- P143
- P144
- P145
- P146
- P152
- P153
- P154
- P155
- P156
- P157
- P158
- P159
- P160
- P161
- P162
- P163
- P164
- P165
- P166
- P167
- P168
- P169
- P170
- P171
- P172
- P174
- P175
- P178
- P180
- P181
- P182
- P183
- P184
- P185
- P186
- P187
- P188
- P189
- P190
- P191
- P192
- P193
- P204
- P205
- P206
- P208
- P211
- P212
- P213
- P214
- P216
- P217
- P218
- P219
- P220
- P221
- P223
- P224
- P225
- P226
- P227
- P228
- P231
- P232
- P236
- P238
- P242
- P243
- P246
- P247
- P248
- P255
- P256
- P259
- P266
- P267
- P268
- P270
- P272
- P273
- P274
- P275
- P276
- P277
- P280
- P282
- P283
- P284
- P285
- P286
- P287
- P294
- P295
- P296
- P297
- P298
- P299
- P300
- P301
- P302
- P303
- P304
- P305
- P306
- P307
- P308
- P309
- P310
- P311
- P312
- P313
- P314
- P316
- P317
- P318
- P319
- P320
- P321
- P322
- P323
- P325
- P326
- P327
- P328
- P329
- P330
- P334
- P335
- P337
- P338
- P339
- P340
- P342
- P344
- P345
- P348
- P349
- P350
- P351
- P355
- P356
- P360
- P368
- P372
- P377
- P380
- P381
- P384
- P385
- P387
- P388
- P390
- P391
- P394
- P396
- P397
- P398
- P399
- P400
- P402
- P403
- P404
- P405
- P406
- P407
- P409
- P410
- P411
- P412
- P413
- P414
- P415
- P416
- P417
- P418
- P419
- P420
- P422
- P423
- P424
- P425
- P426
- P427
- P428
- P429
- P430
- P431
- P432
- P433
- P436
- P442
- P443
- P444
- P445
- P446
- P447
- P448
- P449
- P450
- P451
- P452
- P453
- P454
- P455
- P456
- P458
- P459
- P460
- P461
- P462
- P464
- P465
- P466
- P467
- P468
- P470
- P471
- P472
- P473
- P474
- P477
- P481
- P482
- P483
- P486
- P487
- P488
- P489
- P490
- P493
- P494
- P495
- P496
- P499
- P502
- P503
- P504
- P505
- P506
- P508
- P509
- P510
- P511
- P512
- P514
- P515
- P516
- P517
- P518
- P522
- P533
- P535
- P539
- P541
- P555
- P557
- P561
- P562
- P578
- P579
- P580
- P586
- P591
- P593
- P594
- P595
- P596
- P597
- P598
- P599
- P600
- P602
- P603
- P604
- P605
- P606
- P607
- P608
- P609
- P610
- P611
- P612
- P613
- P614
- P615
- P616
- P617
- P618
- P619
- P620
- P621
- P622
- P623
- P624
- P625
- P626
- P627
- P628
- P629
- P630
- P631
- P632
- P633
- P634
- P635
- P636
- P637
- P638
- P639
- P640
- P641
- P642
- P643
- P644
- P645
- P646
- P647
- P648
- P649
- P652
- P653
- P654
- P655
- P656
- P657
- P658
- P659
- P661
- P663
- P664
- P665
- P666
- P667
- P668
- P669
- P670
- P671
- P672
- P673
- P674
- P675
- P676
- P677
- P680
- P682
- P683
- P684
- P685
- P687
- P690
- P692
- P693
- P694
- P695
- P696
- P697
- P698
- P699
- P700
- P701
- P702
- P703
- P704
- P705
- P706
- P707
- P708
- P709
- P710
- P711
- P712
- P713
- P714
- P715
- P716
- P717
- P718
- P719
- P720
- P721
- P722
- P723
- P727
- P729
- P730
- P731
- P732
- P733
- P734
- P736
- P737
- P738
- P740
- P741
- P742
- P743
- P744
- P745
- P746
- P748
- P749
- P750
- P756
- P758
- P760
- P761
- P768
- P769
- P773
- P774
- P775
- P776
- P779
- P780
- P781
- P782
- P785
- P786
- P787
- P790
- P791
- P794
- P795
- P797
- P798
- P800
- P801
- P802
- P803
- P804
- P805
- P806
- P807
- P808
- P809
- P810
- P811
- P812
- P813
- P814
- P815
- P817
- P821
- P822
- P824
- P826
- P828
- P829
- P830
- P831
- P832
- P833
- P834
- P837
- P841
- P842
- P845
- P848
- P856
- P857
- P858
- P859
- P862
- P863
- P866
- P867
- P868
- P871
- P872
- P876
- P877
- P878
- P879
- P880
- P884
- P885
- P887
- P889
- P890
- P893
- P894
- P895
- P896
- P901
- P902
- P903
- P904
- P905
- P913
- P917
- P918
- P925
- P926
- P930
- P931
- P941
- P949
- P952
- P954
- P955
- P956
- P958
- P959
- P960
- P961
- P962
- P964
- P965
- P966
- P967
- P968
- P969
- P970
- P971
- P972
- P973
- P974
- P975
- P976
- P978
- P979
- P980
- P981
- P982
- P983
- P984
- P991
- P992
- P993
- P994
- P1006
- P1008
- P1009
- P1010
- P1014
- P1015
- P1016
- P1020
- P1021
- P1024
- P1025
- P1027
- P1040
- P1043
- P1044
- P1045
- P1047
- P1048
- P1049
- P1056
- P1057
- P1058
- P1062
- P1064
- P1071
- P1074
- P1076
- P1077
- P1084
- P1092
- P1094
- P1102
- P1107
- P1110
- P1114
- P1115
- P1117
- P1122
- P1127
- P1128
- P1137
- P1138
- P1139
- P1153
- P1156
- P1157
- P1158
- P1159
- P1160
- P1161
- P1162
- P1163
- P1164
- P1166
- P1168
- P1169
- P1176
- P1178
- P1179
- P1180
- P1181
- P1182
- P1200
- P1207
- P1209
- P1301
- P1303
- P1307
- P1313
- P1314
- P1364
- P1380
- P1384
- P1548
- P1554
- P1564
- P1568
- P1574
- P1575
- P1599
- P1666
- P1728
- P1743
- P1756
- P1798
- P1861
- P1865
- P1866
- P1868
- P1870
- P1876
- P1877
- P1888
- P1895
- P1897
- P1898
- P1899
- P1900
- P1901
- P1902
- P1903
- P1904
- P1910
- P1913
- P1914
- P1918
- P1923
- P1926
- P1930
- P1932
- P1933
- P1934
- P1935
- P1936
- P1937
- P1938
- P1939
- P1940
- P1941
- P1942
- P1965
- P1966
- P1967
- P1968
- P1969
- P1970
- P1971
- P1972
- P1973
- P1974
- P1975
- P1976
- P1977
- P1978
- P1987
- P1988
- P1997
- P2001
- P2002
- P2003
- P2005
- P2006
- P2007
- P2008
- P2009
- P2010
- P2011
- P2012
- P2013
- P2014
- P2015
- P2016
- P2017
- P2019
- P2020
- P2023
- P2024
- P2025
- P2027
- P2031
- P2032
- P2033
- P2035
- P2037
- P2038
- P2039
- P2043
- P2044
- P2045
- P2059
- P2078
- P2079
- P2081
- P2082
- P2104
- P2105
- P2106
- P2107
- P2108
- P2113
- P2114
- P2130
- P2137
- P2140
- P2143
- P2144
- P2146
- P2149
- P2161
- P2162
- P2169
- P2209
- P2213
- P2214
- P2228
- P2233
- P2234
- P2235
- P2236
- P2237
- P2241
- P2248
- P2250
- P2252
- P2253
- P2256
- P2260
- P2261
- P2266
- P2268
- P2269
- P2270
- P2271
- P2272
- P2273
- P2274
- P2275
- P2276
- P2277
- P2281
- P2293
- P2302
- P2304
- P2306
- P2307
- P2308
- P2349
- P2350
- P2351
- P2352
- P2353
- P2356
- P2360
- P2376
- P2385
- P2402
- P2407
- P2420
- P2446
- P2465
- P2477
- P2502
- P2569
- P2636
- P2637
- P2638
- P2639
- P2640
- P2641
- P2642
- P2643
- P2646
- P2651
- P2652
- P2664
- P2666
- P2668
- P2678
- P2682
- P2684
- P2715
- P2717
- P2719
- P2740
- P2746
- P2750
- P2752
- P2759
- P2763
- P2810
- P2812
- P2813
- P2814
- P2815
- P2816
- P2820
- P2821
- P2822
- P2834
- P2841
- P2842
- P2843
- P2848
- P2849
- P2850
- P2851
- P2852
- P2853
- P2854
- P2855
- P2858
- P2859
- P2860
- P2861
- P2872
- P2873
- P2888
- P2894
- P2895
- P2896
- P2900
- P2906
- P2907
- P2908
- P2909
- P2912
- P2913
- P2914
- P2916
- P2917
- P2920
- P2926
- P2927
- P2931
- P2932
- P2935
- P2937
- P2942
- P2943
- P2945
- P2947
- P2958
- P2967
- P2979
- P2983
- P2984
- P2987
- P2988
- P2990
- P2996
- P2999
- P3001
- P3002
- P3003
- P3004
- P3005
- P3006
- P3007
- P3008
- P3009
- P3010
- P3011
- P3012
- P3013
- P3014
- P3015
- P3016
- P3017
- P3018
- P3019
- P3020
- P3021
- P3022
- P3023
- P3024
- P3025
- P3026
- P3027
- P3028
- P3029
- P3030
- P3031
- P3032
- P3033
- P3034
- P3035
- P3039
- P3042
- P3044
- P3048
- P3050
- P3058
- P3071
- P3072
- P3091
- P3101
- P3102
- P3103
- P3122
- P3124
- P3153
- P3156
- P3170
- P3177
- P3202
- P3205
- P3206
- P3207
- P3208
- P3251
- P3261
- P3268
- P3281
- P3286
- P3305
- P3412
- P3465
- P3529
- P3566
- P3602
- P3606
- P3615
- P3616
- P3619
- P3623
- P3624
- P3650
- P3651
- P3667
- P3677
- P3680
- P3692
- P3707
- P3708
- P3711
- P3712
- P3713
- P3714
- P3721
- P3749
- P3948
- P3952
- P3956
- P4026
- P4027
- P4028
- P4030
- P4031
- P4032
- P4034
- P4037
- P4038
- P4039
-
最近活动
- 2024年国庆C2025&G2027届赛前训练 IOI
- 2024年国庆C2025&G2027届常规训练 IOI
- 2024年8月31日月末测试(C2025届&C2026届) OI
- 2024年8月普及组初赛模拟题 OI
- C2024&C2025届2024年暑假知识巩固赛 乐多
- 2024年暑假高温测试 IOI
- 2024年暑假集训测试(20240721) OI
- 2024年7月3日C2025届周末测试 乐多
- 2024年6月5日~初二~为高考加油哦 乐多
- 教师基础语法练习 作业
- 2024年4月30日~假期快乐~clone 作业
- 2024年5月2日~主打一个随心 IOI
- 2024年4月30日~假期快乐~ IOI
- 图论基础 作业
- 20240404_速度赛 作业
- 搜索剪枝 作业
- 语法基础_数组 作业
- 搜索基础 作业
- C2025届2024年3月8日练习赛 乐多
- C2025届2024年3月2日开学赛 乐多
- C2025届2024年2月18日知识巩固赛 乐多
- C2025届2024年2月8日新春赛 乐多
- C2025届2024年2月4日立春赛 OI
- C2026届2024年1月31日新年赛~Happy New Year OI
- C2025届2024年1月30日欢乐赛~Happy OI
- 7.dfs 作业
- C2026届2024年1月27日-寒假集训 作业
- C2025届2024年1月27日-寒假集训 作业
- C2026届2023年12月31日元旦跨年赛 OI
- C2025届2023年12月31日元旦跨年赛 OI
- C2026届2023年12月分支结构练习 作业
- C2026届2023年12月顺序结构练习 作业
- 6.栈_队列 作业
- 5.二分 作业
- C2026届2023年11月练习 作业
- C2025届2023年11-12月练习 作业
- C2025届2023年11月18日练习_排序 作业
- 教师练题之二维数组 作业
- 教师练题之一维数组 作业
- 教师练题之循环 作业
- C2025届2023年10月20日练习_STL 作业
- C2024届2023年10月19日复赛前练习 OI
- C2025届2023年国庆练习(20231003) IOI
- C2025届2023年国庆练习(20231005) OI
- C2025届2023年中秋节练习(20230930) IOI
- C2025届2023年国庆前练习(20230928) IOI
- 2023年初赛知识练习(20230915) OI
- 2023年CSP-J练习(20230830) OI
- 2023年暑期初赛知识练习(20230829) OI
- C2025届2023年暑期CSP-J练习(20230828) OI
- C2025届2023年暑期练习 作业
- C2025届暑期二阶上练习题(20230730) OI
- C2025届普及组二阶(上)练习(20230725) OI
- C2024届二阶(下)测试题(20230723) OI
- C2025届普及组一阶测试(校本部20230718) OI
- C2024届二阶(下)练习题(20230717)【模拟,DFS】 IOI
- C2025届普及组一阶总复习(20230715) 作业
- C2025届普及组一阶测试(20230715) OI
- C2025届普及组一阶基础知识测试(20230704) IOI
- C2025届普及组一阶基础知识测试(20230610) OI
- C2025届普及组一阶中期测试(20230605) OI
- C2025届循环结构练习3周日班(20230521) 作业
- C2025届循环结构练习2周日班(20230516) 作业
- C2025届循环结构练习1周日班(20230504) 作业
- C2024届五一练习(2023429) 作业
- C2025届选择结构练习周日班(20230413) 作业
题目标签
- 基础语法
- 291
- 分支问题
- 114
- 数组问题
- 108
- 字符串
- 91
- 简单循环
- 82
- 基础问题
- 79
- 普及组
- 65
- 二维数组
- 51
- noip
- 49
- 顺序
- 45
- 动态规划
- 45
- 递归
- 44
- 其他
- 39
- dp
- 39
- 搜索
- 38
- 结构体
- 38
- 数据结构
- 37
- 顺序结构
- 36
- 嵌套循环
- 36
- 一维数组
- 35