【回溯法】游戏竞赛

题目描述

某游戏规则中,甲乙双方战斗,每一回合总能分出胜负,游戏规定:
1.失败的一方要将自己体力值的1/4加给胜利的一方。
2.游戏开始时,甲的体力值是1000,乙的体力值是2000。
3.每一回合,甲乙胜利的概率均为50%。
求解4个回合后,双方体力值之差小于1000的概率。

分析

每一回合结束,要么甲赢,要么乙赢。n个回合,那么有2^n种结果,采用回溯法从解空间中,中找出abs(a-b)<1000的结果即可。

代码

#include<stdio.h>
#include<stdlib.h>
#define MAX 1000
int i=1,count=0;
float m=1000,a=1000,n=1000,b=1000;
void backdate(int n);
int sum;
int main()
{
    scanf("%d",&sum);
    backdate(1);
    printf("%d",count);
    return 0;
}
void backdate(int i)
{
    float tmp;
    int j;
    if(i>sum)
    {
        if(abs(a-b)<1000)
            count++;
        return ;
    }
    m=a,n=b;        
    a+=b/4;
    b-=b/4;
    backdate(i+1);
    a=m,b=n;
    b+=a/4;
    a-=a/4;
    backdate(i+1);  
    return;
}
    原文作者:回溯法
    原文地址: https://blog.csdn.net/ww1473345713/article/details/52093770
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞