我如何在c++中实现它呢?
How might I implement this into C++?
所以,我在c++中实现这个数学问题时遇到了一些问题。
假设我有一个包含两个随机结果的游戏,这些结果可以是赢或输。
算法解释如下:http://imageshack.us/f/98/terriblyexplained.png/
例如,如果游戏的前6轮是赢、输、赢、赢、输、输,那么第7轮获胜的几率将是78.90625%,而失败的几率将是21.09375%。
我如何将这个场景实现到公式中,并将其实现到可以在c++中运行的算法中?
#include <iostream>
#include <string>
int main()
{
double WinChance = 0.5;
double LossChance = 0.5;
std::string result;
while(std::cin >> result)
{
if(result == "Win")
{
WinChance /= 2.0;
LossChance = 1.0 - WinChance;
}
else
{
LossChance /= 2.0;
WinChance = 1.0 - LossChance;
}
}
std::cout << "Winning Chance next round is " << WinChance * 100.0 << std::endl;
std::cout << "Losing Chance next round is " << LossChance * 100.0 << std::endl;
}
您可以根据当前WinChance
随机生成结果,而不是输入结果。
那么你知道确切的数学过程了,你的问题是关于什么的?
为了不单独存储输赢概率:
double nextWinProbability(double winProb, bool lastWasWin)
{
if (lastWasWin) {
return winProb / 2;
}
else {
return 50 + winProb / 2; // = 100 - loseProb / 2 = 100 - (100 - winProb) / 2
}
}
你不妨不把概率表示为百分比,而是表示为0.0和1.0之间的值。
相关文章:
- 如果没有malloc,链表实现将失败
- 如何在c++中实现处理器调度模拟器
- 如何在c++中使用引用实现类似python的行为
- 实现无开销push_back的最佳方法是什么
- 使用简单类型列表实现的指数编译时间.为什么
- 如何在BST的这个简单递归实现中消除警告
- 实现一个在集合上迭代的模板函数
- 我应该实现右值推送功能吗?我应该使用std::move吗
- 如何正确实现和访问运算符的各种自定义枚举器
- C++Union/Struct位域的实现和可移植性
- 这个极客对极客的trie实现是否存在内存泄漏问题
- 在c++中实现LinkedList时,应出现未处理的错误
- 为左值和右值的包装器实现C++范围
- 使用模板进行堆栈实现; "name followed by :: must be a class or namespace"
- 使用GSoap实现ONVIF
- 在用于格式4的arm模拟器中实现功能时的一个问题
- 用于AVX的ln(x)的实现,m256
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 在C++中,如何在类和函数(可能是模板化的)的头中编写完整的实现
- std::random_device是如何实现的