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

o2o电子商务模式的特点/知了seo

o2o电子商务模式的特点,知了seo,wordpress做社区网站,渭南网站制作题目 描述 题目大意 有nnn个人,你要确定一个出场序列。每次新上台的人就会和擂主打一架,胜利的人继续当擂主。题目给出两两之间打架胜利(失败)的概率。 问111选手坚持到最后的最大概率。 思考历程 看这数据范围这么小&#xff0…

题目

描述

在这里插入图片描述

题目大意

nnn个人,你要确定一个出场序列。每次新上台的人就会和擂主打一架,胜利的人继续当擂主。题目给出两两之间打架胜利(失败)的概率。
111选手坚持到最后的最大概率。


思考历程

看这数据范围这么小,立即想到状压DP!
自然而然地想到状态:设fs,if_{s,i}fs,i表示上了台的人的状态为sss,当前擂主为iii的最大概率。
于是我很快就发现了这个方法的bug。每次转移都会有输或硬两种状态,但万一它们以后要合并到一起呢?
假设状态AAA转移到状态BBBCCC,接下来状态BBBCCC又要转移到DDD。按理来说,从AAADDD的这两个不同状态是可以合并的,但怎么合并呢?
没有办法合并啊!它们会被看做是不同的状态,然后取个maxmaxmax
所以我就迷茫了,不知道该怎么做。
开始往什么贪心。结论题方面想……


正解

实际上这题的正解就是状压DP。
我很震惊,难道我找出来的这个东西对答案没有任何影响?
哼,一定是数据错了
然后我就发现了区别:反着和正着的区别。
我一开始并不理解。反着推和正着推有什么不一样吗?状态之间的转移都是一个有向无环图啊!
后来看看题解才发现了本质上的区别:正着推时,每个状态都会被分裂为许多个状态,有些状态在后面还需要合并,有些就不用,这样就很难处理;反着推时,由于我们已经预知了未来,我们只需要从后往前合并状态,并没有什么分裂状态的鬼玩意儿。这样我们就不用想之前的那些情况了。

然后还有另一种神方法,由LYL发明的O(n2)O(n^2)O(n2)贪心做法。
我们思考一下111号选手放在哪里最优。
111号选手要和排在它后面的选手决斗一次,并且必须要胜利,所以概率为这些选手的胜率之积。
胜率总是不超过111的,所以越乘越小。所以将111放在最后面是最优的。
接着我们就用和DP做法一样的思路,从后往前推。设个fif_ifi表示这一个为iii时的最大概率,方程式一样的。
我们贪心地选择其中最大的那个。
接下来就将这个当做新的111号,重复这样的过程。
%%%LYL


代码

状压DP

using namespace std;
#include <cstdio>
#include <cstring>
#include <algorithm>
inline void update(double &a,double b){a<b?a=b:0;}
int n;
double a[18][18];
double f[1<<18][18];
int main(){scanf("%d",&n);for (int i=0;i<n;++i)for (int j=0;j<n;++j)scanf("%lf",&a[i][j]);f[(1<<n)-1][0]=1;for (int i=(1<<n)-2;i>=0;--i)for (int j=0;j<n;++j)if (i>>j&1)for (int k=0;k<n;++k)if (!(i>>k&1))update(f[i][j],f[i|1<<k][j]*a[j][k]+f[i|1<<k][k]*a[k][j]);double ans=0;for (int i=0;i<n;++i)update(ans,f[1<<i][i]);printf("%.7lf\n",ans);return 0;
}

LYL神贪心

using namespace std;
#include <cstdio>
#include <cstring>
#include <algorithm>
#define N 5010
int n;
double a[N][N];
int q[N];
bool vis[N];
double f[N];
int main(){scanf("%d",&n);for (int i=1;i<=n;++i)for (int j=1;j<=n;++j)scanf("%lf",&a[i][j]);vis[q[0]=1]=1;f[0]=-1,f[1]=1;for (int i=1;i<n;++i){int mx=0;for (int j=1;j<=n;++j)if (!vis[j]){f[j]=f[j]*a[j][q[i-1]]+f[q[i-1]]*a[q[i-1]][j];if (f[j]>f[mx])mx=j;}vis[q[i]=mx]=1;}printf("%.7lf\n",f[q[n-1]]);return 0;
}

总结

有时候正着推和反着推真的很不一样……

http://www.lbrq.cn/news/1465723.html

相关文章:

  • 聚美优品一个专注于做特价的网站/推广公司简介
  • 免费做外贸的网站空间/杭州推广平台有哪些
  • 建设厅证书查询网站/seo优化方案
  • 网站平台建设的实训报告/软件开发外包公司
  • 太原做网站的公司哪家好/网站页面优化内容包括哪些
  • 页面精美的网站/免费建站的网站有哪些
  • 做网站分几种/徐州seo顾问
  • 有知道做网站的吗/品牌运营方案
  • 天眼查官网官网/windows 优化大师
  • 工业和信息化网站备案系统/快速建站工具
  • 怎么做网站下载链接/营销网站建设价格
  • 青海省住房和城乡建设网站/vi设计
  • 做网站怎么跟别人讲价/手机怎么建网站
  • 网站优化怎么做效果才好/百度怎么发广告
  • 北京上云网站建设公司/千锋教育可靠吗
  • wordpress主题weisay simple修改版/东莞seo顾问
  • 网站建设及维护机/搜索引擎优化seo专员招聘
  • 深圳平湖网站建设公司/优化搜索关键词
  • ppt做会动彩字网站/百度关键词热搜
  • 要想提高网站排名应该如何做/网络营销的概述
  • 企业应用平台和系统管理/北京网站seo费用
  • 付费软件免费拿/郑州搜狗关键词优化顾问
  • 江西省网站备案/武汉seo工厂
  • 网站css下载/南昌网站优化公司
  • 小男孩与大人做的网站/长春网站推广公司
  • 成都移动网站建设/好搜seo软件
  • 做爰全过程免费狐狸网站/四川网站制作
  • wordpress清理插件/seo是什么化学名称
  • 网站设计一级网页/中国免费网站服务器2020
  • 建设局网站建设方案书/东莞关键词排名优化
  • 题单【模拟与高精度】
  • kotlin小记(1)
  • Linux性能监控与调优全攻略
  • 加密与安全
  • 超越 ChatGPT:智能体崛起,开启全自主 AI 时代
  • 每日练习(红黑树)