对于区间DP,有两种转移方式,一种从内到外,一种从外到内,先讲一下各自的使用范围,对于从外到内,适用于一个序列,只能取两端的,而从内到外是适用与从中间某一个点开始取,从而拓展到全局。先贴上从内到外的。
1 for(int len=1;len<=n;len++) //设置步长 2 for(int l=1;l+len<=n;l++){ //设置左端点 3 int r=l+len; //右端点 4 ---------- 5 ---------- 6 ---------- 7 这里是状态转移 8 }
1 for(int len=n;len>=1;len--) //设置步长 2 for(int l=1;l+len<=n;l++){ //设置左端点 3 int r=l+len; //右端点 4 ---------- 5 ---------- 6 ---------- 7 这里是状态转移 8 }
直接贴题吧。
1.石子合并
2.
3.