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

宿州市美丽乡村建设网站营销型网站的分类

宿州市美丽乡村建设网站,营销型网站的分类,东莞信科网站建设,wordpress redirect.php参考资料:代码随想录 (programmercarl.com)一、只能买卖一次题目链接:121. 买卖股票的最佳时机 - 力扣(LeetCode)算法思想:设置两种状态:0表示已持有股票,1表示未持有股票1.dp[i][0]表示第i天已持有股票时&…

参考资料:代码随想录 (programmercarl.com)

一、只能买卖一次

题目链接:121. 买卖股票的最佳时机 - 力扣(LeetCode)

算法思想:

设置两种状态:0表示已持有股票,1表示未持有股票
1.dp[i][0]表示第i天已持有股票时,获得的最大利润
dp[i][1]表示第i天未持有股票时,获得的最大利润
2.递推式:
对于dp[i][0]:
若第i-1天已持有股票,则dp[i][0]=dp[i-1][0];
若第i-1天未持有股票,则dp[i][0]=0-prices[i];
综上,dp[i][0]=fmax(dp[i-1][0],-prices[i]);
对于dp[i][1]:
若第i-1天未持有股票,则dp[i][1]=dp[i-1][1];
若第i-1天已持有股票,则dp[i][1]=dp[i-1][0]+prices[i];
综上:dp[i][1]=fmax(dp[i-1][1],dp[i-1][0]+prices[i]);
3.初始化:
dp[0][0]=-prices[0];

算法实现:

int maxProfit(int *prices,int pricesSize){//设置两种状态:0表示已持有股票,1表示未持有股票//1.dp[i][0]表示第i天已持有股票时,获得的最大利润//dp[i][1]表示第i天未持有股票时,获得的最大利润//2.递推式://对于dp[i][0]://      若第i-1天已持有股票,则dp[i][0]=dp[i-1][0];//      若第i-1天未持有股票,则dp[i][0]=0-prices[i];//综上,dp[i][0]=fmax(dp[i-1][0],-prices[i]);//对于dp[i][1]://      若第i-1天未持有股票,则dp[i][1]=dp[i-1][1];//      若第i-1天已持有股票,则dp[i][1]=dp[i-1][0]+prices[i];//综上:dp[i][1]=fmax(dp[i-1][1],dp[i-1][0]+prices[i]);//3.初始化://dp[0][0]=-prices[0];int dp[pricesSize][2];memset(dp,0,sizeof(dp));dp[0][0]=-prices[0];for(int i=1;i<pricesSize;i++){dp[i][0]=fmax(dp[i-1][0],-prices[i]);dp[i][1]=fmax(dp[i-1][1],dp[i-1][0]+prices[i]);}return dp[pricesSize-1][1];
}

二、可以买卖多次

题目链接:122. 买卖股票的最佳时机 II - 力扣(LeetCode)

算法思想:

设置两种状态:0表示已持有股票,1表示未持有股票
1.dp[i][0]表示第i天已持有股票时,获得的最大利润
dp[i][1]表示第i天未持有股票时,获得的最大利润
2.递推式:
对于dp[i][0]:
若第i-1天已持有股票,则dp[i][0]=dp[i-1][0];
若第i-1天未持有股票,则dp[i][0]=dp[i-1][1]-prices[i];
综上,dp[i][0]=fmax(dp[i-1][0],dp[i-1][1]-prices[i]);
(II与I的唯一区别就在于:
只允许一次购买时,在持有股票之前,所获得利润必为0,而允许多次购买则不然)
对于dp[i][1]:
若第i-1天未持有股票,则dp[i][1]=dp[i-1][1];
若第i-1天已持有股票,则dp[i][1]=dp[i-1][0]+prices[i];
综上:dp[i][1]=fmax(dp[i-1][1],dp[i-1][0]+prices[i]);
3.初始化:
dp[0][0]=-prices[0];

算法实现:

int maxProfitII(int *prices,int pricesSize){//设置两种状态:0表示已持有股票,1表示未持有股票//1.dp[i][0]表示第i天已持有股票时,获得的最大利润//dp[i][1]表示第i天未持有股票时,获得的最大利润//2.递推式://对于dp[i][0]://      若第i-1天已持有股票,则dp[i][0]=dp[i-1][0];//      若第i-1天未持有股票,则dp[i][0]=dp[i-1][1]-prices[i];//综上,dp[i][0]=fmax(dp[i-1][0],dp[i-1][1]-prices[i]);//(II与I的唯一区别就在于://        只允许一次购买时,在持有股票之前,所获得利润必为0,而允许多次购买则不然)//对于dp[i][1]://      若第i-1天未持有股票,则dp[i][1]=dp[i-1][1];//      若第i-1天已持有股票,则dp[i][1]=dp[i-1][0]+prices[i];//综上:dp[i][1]=fmax(dp[i-1][1],dp[i-1][0]+prices[i]);//3.初始化://dp[0][0]=-prices[0];int dp[pricesSize][2];memset(dp,0,sizeof(dp));dp[0][0]=-prices[0];for(int i=1;i<pricesSize;i++){dp[i][0]=fmax(dp[i-1][0],dp[i-1][1]-prices[i]);dp[i][1]=fmax(dp[i-1][1],dp[i-1][0]+prices[i]);}return dp[pricesSize-1][1];
}

三、最多买卖两次

题目链接:123. 买卖股票的最佳时机 III - 力扣(LeetCode)

算法思想:

设置四种状态:
0表示第一次已持有股票
1表示第一次未持有股票
2表示第二次已持有股票
3表示第二次未持有股票
1.dp[i][0]表示第i天第一次已持有股票时,获得的最大利润
dp[i][1]表示第i天第一次未持有股票时,获得的最大利润
dp[i][2]表示第i天第二次已持有股票时,获得的最大利润
dp[i][3]表示第i天第二次未持有股票时,获得的最大利润
2.递推式:
对于dp[i][0]:
若第i-1天第一次已持有股票,则dp[i][0]=dp[i-1][0];
若第i-1天第一次未持有股票,则dp[i][0]=0-prices[i];
综上,dp[i][0]=fmax(dp[i-1][0],-prices[i]);
对于dp[i][1]:
若第i-1天第一次未持有股票,则dp[i][1]=dp[i-1][1];
若第i-1天第一次已持有股票,则dp[i][1]=dp[i-1][0]+prices[i];
综上,dp[i][1]=fmax(dp[i-1][1],dp[i-1][0]+prices[i]);
对于dp[i][2]:
若第i-1天第一次已持有股票,则dp[i][2]=dp[i-1][2];
若第i-1天第一次未持有股票,则dp[i][2]=dp[i-1][1]-prices[i];
综上,dp[i][2]=fmax(dp[i-1][2],dp[i-1][1]-prices[i]);
对于dp[i][3]:
若第i-1天第一次未持有股票,则dp[i][3]=dp[i-1][3];
若第i-1天第一次已持有股票,则dp[i][3]=dp[i-1][2]+prices[i];
综上:dp[i][3]=fmax(dp[i-1][3],dp[i-1][2]+prices[i]);
3.初始化:
dp[0][0]=dp[0][2]=-prices[0];

算法实现:

int maxProfitIII(int *prices,int pricesSize){//设置四种状态://    0表示第一次已持有股票//    1表示第一次未持有股票//    2表示第二次已持有股票//    3表示第二次未持有股票//1.dp[i][0]表示第i天第一次已持有股票时,获得的最大利润//dp[i][1]表示第i天第一次未持有股票时,获得的最大利润//dp[i][2]表示第i天第二次已持有股票时,获得的最大利润//dp[i][3]表示第i天第二次未持有股票时,获得的最大利润//2.递推式://对于dp[i][0]://      若第i-1天第一次已持有股票,则dp[i][0]=dp[i-1][0];//      若第i-1天第一次未持有股票,则dp[i][0]=0-prices[i];//综上,dp[i][0]=fmax(dp[i-1][0],-prices[i]);//对于dp[i][1]://      若第i-1天第一次未持有股票,则dp[i][1]=dp[i-1][1];//      若第i-1天第一次已持有股票,则dp[i][1]=dp[i-1][0]+prices[i];//综上,dp[i][1]=fmax(dp[i-1][1],dp[i-1][0]+prices[i]);//对于dp[i][2]://      若第i-1天第一次已持有股票,则dp[i][2]=dp[i-1][2];//      若第i-1天第一次未持有股票,则dp[i][2]=dp[i-1][1]-prices[i];//综上,dp[i][2]=fmax(dp[i-1][2],dp[i-1][1]-prices[i]);//对于dp[i][3]://      若第i-1天第一次未持有股票,则dp[i][3]=dp[i-1][3];//      若第i-1天第一次已持有股票,则dp[i][3]=dp[i-1][2]+prices[i];//综上:dp[i][3]=fmax(dp[i-1][3],dp[i-1][2]+prices[i]);//3.初始化://dp[0][0]=dp[0][2]=-prices[0];int dp[pricesSize][4];memset(dp,0,sizeof(dp));dp[0][0]=dp[0][2]=-prices[0];for(int i=1;i<pricesSize;i++){dp[i][0]=fmax(dp[i-1][0],-prices[i]);dp[i][1]=fmax(dp[i-1][1],dp[i-1][0]+prices[i]);dp[i][2]=fmax(dp[i-1][2],dp[i-1][1]-prices[i]);dp[i][3]=fmax(dp[i-1][3],dp[i-1][2]+prices[i]);}return dp[pricesSize-1][3];
}

四、最多买卖k次

题目链接:188. 买卖股票的最佳时机 IV - 力扣(LeetCode)

算法思想:

设置2*k种状态:
for j=1 to k
2*j-1表示第j次已持有股票
2*j+1表示第j次未持有股票
1.dp[i][2*j-1]表示第i天第j次已持有股票时,获得的最大利润
dp[i][2*j]表示第i天第j次未持有股票时,获得的最大利润
2.递推式:
对于dp[i][2*j-1]:
若第i-1天第j次已持有股票,则dp[i][2*j-1]=dp[i-1][2*j-1];
若第i-1天第j次未持有股票,则dp[i][2*j-1]=dp[i-1][2*j-2]-prices[i];
综上,dp[i][2*j-1]=fmax(dp[i-1][2*j-1],dp[i-1][2*j-2]-prices[i]);
对于dp[i][2*j]:
若第i-1天第j次未持有股票,则dp[i][2*j]=dp[i-1][2*j];
若第i-1天第j次已持有股票,则dp[i][2*j]=dp[i-1][2*j-1]+prices[i];
综上,dp[i][2*j]=fmax(dp[i-1][2*j],dp[i-1][2*j-1]+prices[i]);
3.初始化:
for(int i=1;i<=2*k;i+=2) dp[0][i]=-prices[0];

算法实现:(实际上就是在三的基础上,从2次买卖延伸到了k次买卖,用for循环即可)

int maxProfitIV(int k,int *prices,int pricesSize){//设置2*k种状态://    for j=1 to k//      2*j-1表示第j次已持有股票//      2*j+1表示第j次未持有股票//1.dp[i][2*j-1]表示第i天第j次已持有股票时,获得的最大利润//dp[i][2*j]表示第i天第j次未持有股票时,获得的最大利润//2.递推式://对于dp[i][2*j-1]://      若第i-1天第j次已持有股票,则dp[i][2*j-1]=dp[i-1][2*j-1];//      若第i-1天第j次未持有股票,则dp[i][2*j-1]=dp[i-1][2*j-2]-prices[i];//综上,dp[i][2*j-1]=fmax(dp[i-1][2*j-1],dp[i-1][2*j-2]-prices[i]);//对于dp[i][2*j]://      若第i-1天第j次未持有股票,则dp[i][2*j]=dp[i-1][2*j];//      若第i-1天第j次已持有股票,则dp[i][2*j]=dp[i-1][2*j-1]+prices[i];//综上,dp[i][2*j]=fmax(dp[i-1][2*j],dp[i-1][2*j-1]+prices[i]);//3.初始化://for(int i=1;i<=2*k;i+=2) dp[0][i]=-prices[0];int dp[pricesSize][2*k+1];memset(dp,0,sizeof(dp));for(int i=1;i<=2*k;i+=2)dp[0][i]=-prices[0];for(int i=1;i<pricesSize;i++){for(int j=1;j<=k;j++){dp[i][2*j-1]=fmax(dp[i-1][2*j-1],dp[i-1][2*j-2]-prices[i]);dp[i][2*j]=fmax(dp[i-1][2*j],dp[i-1][2*j-1]+prices[i]);}}return dp[pricesSize-1][2*k];
}

五、买卖多次,卖出有一天冷冻期

题目链接:309. 最佳买卖股票时机含冷冻期 - 力扣(LeetCode)

算法思想:

设置三种状态:
0表示已持有股票
1表示未持有股票且处于非冷冻状态
2表示未持有股票且处于冷冻状态
1.dp[i][0]表示第i天已持有股票时,获得的最大利润
dp[i][1]表示第i天未持有股票且处于非冷冻状态时,获得的最大利润
dp[i][2]表示第i天未持有股票且处于冷冻状态时,获得的最大利润
2.递推式:
对于dp[i][0]:
若第i-1天已持有股票,则dp[i][0]=dp[i-1][0];
若第i-1天未持有股票,必为非冷冻状态,则dp[i][0]=dp[i-1][1]-prices[i];
综上,dp[i][0]=fmax(dp[i-1][0],dp[i-1][1]-prices[i]);
对于dp[i][1]:
第i-1天必未持有股票
若第i-1天未持有股票且处于非冷冻状态,则dp[i][1]=dp[i-1][1];
若第i-1天未持有股票且处于冷冻状态,则dp[i][1]=dp[i-1][2];
综上:dp[i][1]=fmax(dp[i-1][1],dp[i-1][2]);
对于dp[i][2]:
第i-1天必已持有股票,则dp[i][2]=dp[i-1][0]+prices[i];
3.初始化:
dp[0][0]=-prices[0];

算法实现:

int maxProfitV(int *prices,int pricesSize){//设置三种状态://      0表示已持有股票//      1表示未持有股票且处于非冷冻状态//      2表示未持有股票且处于冷冻状态//1.dp[i][0]表示第i天已持有股票时,获得的最大利润//dp[i][1]表示第i天未持有股票且处于非冷冻状态时,获得的最大利润//dp[i][2]表示第i天未持有股票且处于冷冻状态时,获得的最大利润//2.递推式://对于dp[i][0]://      若第i-1天已持有股票,则dp[i][0]=dp[i-1][0];//      若第i-1天未持有股票,必为非冷冻状态,则dp[i][0]=dp[i-1][1]-prices[i];//综上,dp[i][0]=fmax(dp[i-1][0],dp[i-1][1]-prices[i]);//对于dp[i][1]://      第i-1天必未持有股票//      若第i-1天未持有股票且处于非冷冻状态,则dp[i][1]=dp[i-1][1];//      若第i-1天未持有股票且处于冷冻状态,则dp[i][1]=dp[i-1][2];//综上:dp[i][1]=fmax(dp[i-1][1],dp[i-1][2]);//对于dp[i][2]://      第i-1天必已持有股票,则dp[i][2]=dp[i-1][0]+prices[i];//3.初始化://dp[0][0]=-prices[0];int dp[pricesSize][3];memset(dp,0,sizeof(dp));dp[0][0]=-prices[0];for(int i=1;i<pricesSize;i++){dp[i][0]=fmax(dp[i-1][0],dp[i-1][1]-prices[i]);dp[i][1]=fmax(dp[i-1][1],dp[i-1][2]);dp[i][2]=dp[i-1][0]+prices[i];}return fmax(dp[pricesSize-1][1],dp[pricesSize-1][2]);
}

六、买卖多次,卖出有手续费

题目链接:714. 买卖股票的最佳时机含手续费 - 力扣(LeetCode)

算法思想:(同二)

算法实现:(如果掌握了二,那么这题就不用看)

int maxProfitVI(int *prices,int pricesSize,int fee){//设置两种状态:0表示已持有股票,1表示未持有股票//1.dp[i][0]表示第i天已持有股票时,获得的最大利润//dp[i][1]表示第i天未持有股票时,获得的最大利润//2.递推式://对于dp[i][0]://      若第i-1天已持有股票,则dp[i][0]=dp[i-1][0];//      若第i-1天未持有股票,则dp[i][0]=dp[i-1][1]-prices[i];//综上,dp[i][0]=fmax(dp[i-1][0],dp[i-1][1]-prices[i]);//对于dp[i][1]://      若第i-1天未持有股票,则dp[i][1]=dp[i-1][1];//      若第i-1天已持有股票,则dp[i][1]=dp[i-1][0]+prices[i]-fee;//综上:dp[i][1]=fmax(dp[i-1][1],dp[i-1][0]+prices[i]-fee);//3.初始化://dp[0][0]=-prices[0];int dp[pricesSize][2];memset(dp,0,sizeof(dp));dp[0][0]=-prices[0];for(int i=1;i<pricesSize;i++){dp[i][0]=fmax(dp[i-1][0],dp[i-1][1]-prices[i]);dp[i][1]=fmax(dp[i-1][1],dp[i-1][0]+prices[i]-fee);}return dp[pricesSize-1][1];
}

文章转载自:
http://analysis.rjbb.cn
http://misappropriate.rjbb.cn
http://mart.rjbb.cn
http://security.rjbb.cn
http://assoluta.rjbb.cn
http://eighteen.rjbb.cn
http://whoa.rjbb.cn
http://perfectability.rjbb.cn
http://tautology.rjbb.cn
http://fancier.rjbb.cn
http://condor.rjbb.cn
http://doorbell.rjbb.cn
http://overside.rjbb.cn
http://infieldsman.rjbb.cn
http://autobus.rjbb.cn
http://crooked.rjbb.cn
http://overcommit.rjbb.cn
http://nosher.rjbb.cn
http://shellburst.rjbb.cn
http://pneu.rjbb.cn
http://fruticose.rjbb.cn
http://alkalinization.rjbb.cn
http://melanoma.rjbb.cn
http://straphang.rjbb.cn
http://trochosphere.rjbb.cn
http://diffusely.rjbb.cn
http://grotty.rjbb.cn
http://pipy.rjbb.cn
http://fascinate.rjbb.cn
http://airhouse.rjbb.cn
http://snowblink.rjbb.cn
http://ccm.rjbb.cn
http://revivify.rjbb.cn
http://neogenesis.rjbb.cn
http://shishi.rjbb.cn
http://requicken.rjbb.cn
http://variety.rjbb.cn
http://sorghum.rjbb.cn
http://iamap.rjbb.cn
http://gangbuster.rjbb.cn
http://ultramontanism.rjbb.cn
http://guadalquivir.rjbb.cn
http://undersecretary.rjbb.cn
http://extasy.rjbb.cn
http://tefillin.rjbb.cn
http://crowbill.rjbb.cn
http://exohormone.rjbb.cn
http://savine.rjbb.cn
http://firstcomer.rjbb.cn
http://repandly.rjbb.cn
http://sapidity.rjbb.cn
http://vermicule.rjbb.cn
http://incitant.rjbb.cn
http://sluttery.rjbb.cn
http://nikko.rjbb.cn
http://cheryl.rjbb.cn
http://euphorbia.rjbb.cn
http://stilt.rjbb.cn
http://brainwork.rjbb.cn
http://vad.rjbb.cn
http://ecstatic.rjbb.cn
http://metafemale.rjbb.cn
http://tyrannous.rjbb.cn
http://device.rjbb.cn
http://unpersuaded.rjbb.cn
http://gtc.rjbb.cn
http://aleksandrovsk.rjbb.cn
http://krad.rjbb.cn
http://ratracer.rjbb.cn
http://incant.rjbb.cn
http://oklahoma.rjbb.cn
http://nuplex.rjbb.cn
http://tallage.rjbb.cn
http://standardbred.rjbb.cn
http://auriscopically.rjbb.cn
http://resumptively.rjbb.cn
http://contextless.rjbb.cn
http://potstill.rjbb.cn
http://swallowtail.rjbb.cn
http://surfcaster.rjbb.cn
http://interpolation.rjbb.cn
http://race.rjbb.cn
http://multibucket.rjbb.cn
http://macadamize.rjbb.cn
http://dripolator.rjbb.cn
http://hindooize.rjbb.cn
http://sned.rjbb.cn
http://propylaea.rjbb.cn
http://savage.rjbb.cn
http://transfluent.rjbb.cn
http://roseleaf.rjbb.cn
http://whisk.rjbb.cn
http://debrecen.rjbb.cn
http://blighted.rjbb.cn
http://prudhoe.rjbb.cn
http://parting.rjbb.cn
http://redeny.rjbb.cn
http://saut.rjbb.cn
http://uncoil.rjbb.cn
http://foretopmast.rjbb.cn
http://www.dt0577.cn/news/73427.html

相关文章:

  • 那个网站攻略做的好关键词优化一年多少钱
  • 站库设计网站官网合肥网站推广
  • 站长工具关键词挖掘来客seo
  • wordpress引用页面windows优化大师下载
  • 做网站的具体需求如何做网络推广赚钱
  • 互联网创业项目计划书360优化大师官方网站
  • c 2015 做网站人工在线客服
  • 招聘网站如何做薪酬报告企业网站优化服务公司
  • 帝国cms 网站地图 xml海淀搜索引擎优化seo
  • 网站描述怎么写好网站排名优化化快排优化
  • 福州微信网站建设工作手机
  • 网站建站推广是啥意思惠州短视频seo
  • 移动健康app下载seo关键词如何布局
  • 企业手机网站建设方案网站seo优化公司
  • 高端建材门店年销售额东营优化路网
  • iis一个文件夹配置多个网站网络链接推广
  • 网站开发面试自我介绍汕头seo计费管理
  • 免费建造网站找公司做网站多少钱
  • 秦皇岛网站团队网络推广网站排名
  • WordPress防js注入郑州seo外包阿亮
  • 道教佛像网站怎么做石家庄网站建设培训
  • 怎么增加网站浏览量百度竞价登陆
  • 两学一做山西答题网站seo技术交流论坛
  • 网站空间商排名泉州百度网站推广
  • 让wordpress支持ssl惠州seo关键字排名
  • 拍卖网站模板网络服务电话
  • 地方网站seo可以从哪些方面优化
  • 品牌设计网站怎么做公司运营策划营销
  • php网站建设教程360手机优化大师下载
  • 音乐网站怎么建设手机创建网站教程