当前位置: 首页 > wzjs >正文

台州优化排名推广花都网络推广seo公司

台州优化排名推广,花都网络推广seo公司,app官网入口,凡科做网站技巧题目链接 https://www.luogu.com.cn/problem/P1850 思路 令 f [ i ] [ j ] [ 0 / 1 ] f[i][j][0/1] f[i][j][0/1]分别表示已经上完前 i i i节课,使用了 j j j次交换申请,且第 i i i节课不适用交换申请 o r or or第 i i i节课使用交换申请的移动耗费的…

题目链接

https://www.luogu.com.cn/problem/P1850

思路

f [ i ] [ j ] [ 0 / 1 ] f[i][j][0/1] f[i][j][0/1]分别表示已经上完前 i i i节课,使用了 j j j次交换申请,且第 i i i节课不适用交换申请 o r or or i i i节课使用交换申请的移动耗费的体力值的总和的期望值的最小值。

d i s t [ i ] [ j ] dist[i][j] dist[i][j]表示从第 i i i个教室到第 j j j个教室的最短路,因为数据范围较小,使用 f l o y d floyd floyd求解即可。

则状态转移方程为:

f [ i ] [ j ] [ 0 ] = m i n ( f [ i ] [ j ] [ 0 ] , f [ i − 1 ] [ j ] [ 0 ] + d i s t [ c [ i − 1 ] ] [ c [ i ] ] ) f[i][j][0] = min(f[i][j][0],f[i - 1][j][0] + dist[c[i - 1]][c[i]]) f[i][j][0]=min(f[i][j][0],f[i1][j][0]+dist[c[i1]][c[i]])

f [ i ] [ j ] [ 0 ] = m i n ( f [ i ] [ j ] [ 0 ] , f [ i − 1 ] [ j ] [ 1 ] + ( 1 − k [ i − 1 ] ) ∗ d i s t [ c [ i − 1 ] ] [ c [ i ] ] + k [ i − 1 ] ∗ d i s t [ d [ i − 1 ] ] [ c [ i ] ] ) f[i][j][0] = min(f[i][j][0],f[i - 1][j][1] + (1 - k[i - 1]) * dist[c[i - 1]][c[i]] + k[i - 1] * dist[d[i - 1]][c[i]]) f[i][j][0]=min(f[i][j][0],f[i1][j][1]+(1k[i1])dist[c[i1]][c[i]]+k[i1]dist[d[i1]][c[i]])

f [ i ] [ j ] [ 1 ] = m i n ( f [ i ] [ j ] [ 1 ] , f [ i − 1 ] [ j − 1 ] [ 0 ] + ( 1 − k [ i ] ) ∗ d i s t [ c [ i − 1 ] ] [ c [ i ] ] + k [ i ] ∗ d i s t [ c [ i − 1 ] ] [ d [ i ] ] ) f[i][j][1] = min(f[i][j][1],f[i - 1][j - 1][0] + (1 - k[i]) * dist[c[i - 1]][c[i]] + k[i] * dist[c[i - 1]][d[i]]) f[i][j][1]=min(f[i][j][1],f[i1][j1][0]+(1k[i])dist[c[i1]][c[i]]+k[i]dist[c[i1]][d[i]])

f [ i ] [ j ] [ 1 ] = m i n ( f [ i ] [ j ] [ 1 ] , f [ i − 1 ] [ j − 1 ] [ 1 ] + ( 1 − k [ i − 1 ] ) ∗ ( 1 − k [ i ] ) ∗ d i s t [ c [ i − 1 ] ] [ c [ i ] ] + k [ i − 1 ] ∗ ( 1 − k [ i ] ) ∗ d i s t [ d [ i − 1 ] ] [ c [ i ] ] + ( 1 − k [ i − 1 ] ) ∗ k [ i ] ∗ d i s t [ c [ i − 1 ] ] [ d [ i ] ] + k [ i − 1 ] ∗ k [ i ] ∗ d i s t [ d [ i − 1 ] ] [ d [ i ] ] ) f[i][j][1] = min(f[i][j][1],f[i - 1][j - 1][1]+(1 - k[i - 1]) * (1 - k[i]) * dist[c[i - 1]][c[i]]+k[i - 1] * (1 - k[i]) * dist[d[i - 1]][c[i]]+(1 - k[i - 1]) * k[i] * dist[c[i - 1]][d[i]]+k[i - 1] * k[i] * dist[d[i - 1]][d[i]]) f[i][j][1]=min(f[i][j][1],f[i1][j1][1]+(1k[i1])(1k[i])dist[c[i1]][c[i]]+k[i1](1k[i])dist[d[i1]][c[i]]+(1k[i1])k[i]dist[c[i1]][d[i]]+k[i1]k[i]dist[d[i1]][d[i]])

代码

#include <bits/stdc++.h>using namespace std;#define int long long
#define double long double
#define endl "\n"typedef long long i64;
typedef unsigned long long u64;
typedef pair<int, int> pii;const int N = 2e3 + 5, M = 3e2 + 5;
const int mod = 1e9 + 7;
const int inf = 1e9;
const double eps = 1e-6;std::mt19937 rnd(time(0));int n, m, v, e;
int c[N], d[N], dist[M][M];
double k[N];
double f[N][N][2];
void floyd(int maxx)
{for (int k = 1; k <= maxx; k++){for (int i = 1; i <= maxx; i++){for (int j = 1; j <= maxx; j++){dist[i][j] = min(dist[i][k] + dist[k][j], dist[i][j]);}}}
}
void solve(int test_case)
{cin >> n >> m >> v >> e;for (int i = 1; i <= n; i++){cin >> c[i];}for (int i = 1; i <= n; i++){cin >> d[i];}for (int i = 1; i <= n; i++){cin >> k[i];}int maxx = 300;for (int i = 1; i <= maxx; i++){for (int j = 1; j <= maxx; j++){dist[i][j] = inf;}}for (int i = 1; i <= maxx; i++)dist[i][i] = 0;for (int i = 1, a, b, w; i <= e; i++){cin >> a >> b >> w;dist[a][b] = min(dist[a][b], w);dist[b][a] = min(dist[b][a], w);}floyd(maxx);for (int i = 1; i <= n; i++){for (int j = 0; j <= min(i, m); j++){f[i][j][0] = f[i][j][1] = (double)(1e18);}}f[1][0][0] = 0;f[1][1][1] = 0;for (int i = 2; i <= n; i++){for (int j = 0; j <= min(i, m); j++){double res = 0;if (j < i){f[i][j][0] = min(f[i][j][0], f[i - 1][j][0] + dist[c[i - 1]][c[i]]);res = f[i - 1][j][1] + ((double)(1) - k[i - 1]) * dist[c[i - 1]][c[i]] + k[i - 1] * dist[d[i - 1]][c[i]];f[i][j][0] = min(f[i][j][0], res);}if (j){res = f[i - 1][j - 1][0] + ((double)(1) - k[i]) * dist[c[i - 1]][c[i]] + k[i] * dist[c[i - 1]][d[i]];f[i][j][1] = min(f[i][j][1], res);res = f[i - 1][j - 1][1];res += ((double)(1) - k[i - 1]) * ((double)(1) - k[i]) * dist[c[i - 1]][c[i]];res += k[i - 1] * ((double)(1) - k[i]) * dist[d[i - 1]][c[i]];res += ((double)(1) - k[i - 1]) * k[i] * dist[c[i - 1]][d[i]];res += k[i - 1] * k[i] * dist[d[i - 1]][d[i]];f[i][j][1] = min(f[i][j][1], res);}}}double ans = 1e18;for (int i = 0; i <= m; i++){ans = min({ans, f[n][i][0], f[n][i][1]});}cout << fixed << setprecision(2) << ans << endl;
}signed main()
{ios::sync_with_stdio(false);cin.tie(0), cout.tie(0);int test = 1;// cin >> test;for (int i = 1; i <= test ; i++){solve(i);}return 0;
}
http://www.dtcms.com/wzjs/183807.html

相关文章:

  • 网站制作高端网站建设网站页面的优化
  • 国企网站建设合同互联网金融
  • centos wordpress 建站教程海淀区seo多少钱
  • 青海省公路建设管理局门户网站磁力宅
  • 徐州方案公示在哪个网站百度一下1688
  • 网站seo推广优化报价表nba总得分排行榜最新
  • 做网站常用的小语种有哪些seo网站管理招聘
  • 重庆餐饮网站设计超级优化
  • php网站怎么做自适应小说关键词提取软件
  • 深圳福田区怎么样seo是什么平台
  • 做电影网站需要什么软件北京sem
  • 莆田的外贸网站网站优化公司怎么选
  • 视频教学互动网站建设正规排名网站推广公司
  • 常德网站建设常德客服外包平台
  • 营销型网站传统网站运城seo
  • 化妆品网站建设流程图网络营销教学网站
  • 云梦网络做网站响应式网站建设
  • 游戏推广应该怎么推广东seo外包服务
  • lnmp wordpress 301网络seo优化公司
  • dede小游戏php网站源码百度经验悬赏任务平台
  • 辽宁专业网站建设北京seo经理
  • 企业网站建设博客论坛免费b2b网站大全免费
  • 农业种植养殖网站建设上海百度seo网站优化
  • 百度一wordpressseo和竞价排名的区别
  • 商务网站建设实训报告产品推广方式
  • 阿里巴巴开通诚信通后网站怎么做网站内容如何优化
  • 做色情灰色网站怎么判刑获客软件
  • 免费wordpress主题seo是什么的简称
  • 中山专业手机网站建设seo关键词优化培训班
  • 怎样把域名和做的网站连接不上免费个人网站建站