时间:2021-05-19
在C#版看到这一篇文章,手边现在正开著MacBook上网
实在不太想重新开Windows跟Visual Studio来编码
正好我也在练习C++ Template,那就很刚好试著用Template来实践一下
复制代码 代码如下:
//
// main.cpp
// RandomTest
//
// Created by Cloud on 2011/4/10.
// Copyright 2011年 Orz. All rights reserved.
//
#include <iostream>
#include <vector>
using namespace std;
template<class T>
class RandomWord
{
T m_Word;
int m_Probability;
public:
RandomWord(T word, int probability):m_Word(word),m_Probability(probability){}
T getWord() { return m_Word; }
int getProbability() { return m_Probability; }
};
template<class T>
class RandManager
{
vector<RandomWord<T> > m_randomList;
int m_sumOfProbability;
public:
RandManager() :m_randomList(), m_sumOfProbability(0)
{
}
void AddRandomWord(RandomWord<T> word)
{
if(m_sumOfProbability <= 100)
m_randomList.push_back(word);
cout<<"Add word:"<<word.getWord()<<endl;
cout<<"Probability:"<<m_sumOfProbability;
cout<<"-"<<word.getProbability() + m_sumOfProbability<<endl;
m_sumOfProbability += word.getProbability();
}
void RandomGenerate(int randNum)
{
cout<<"Random:"<<randNum<<endl;
int sum = 0;
for(int i = 0 ; i < m_randomList.size() ; i++)
{
RandomWord<T> orz = m_randomList[i];
if( (sum <= randNum) && (randNum < (orz.getProbability() + sum)))
{
cout<<"Generate:"<<orz.getWord()<<endl;
break;
}
else
{
sum += orz.getProbability();
}
}
}
};
int main (int argc, const char * argv[])
{
RandManager<char> manager;
manager.AddRandomWord(RandomWord<char>('A',10));
manager.AddRandomWord(RandomWord<char>('B',10));
manager.AddRandomWord(RandomWord<char>('C',35));
manager.AddRandomWord(RandomWord<char>('D',25));
manager.AddRandomWord(RandomWord<char>('E',20));
srand(time(NULL));
manager.RandomGenerate(rand()%100);
return 0;
}
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在Android开发中,有时我们需要对一个对象的集合按照某一个字段进行排序,BeanpublicclassStudent{privateintstudentId
今天遇到个问题,goxorm无法更新某一个字段为0.xxTable:=&models.XXTable{Visible:visible}affected,err:
需求:合并某一个字段的相同项,并且要按照另一个时间字段排序。例子:一开始用selectcityfromtablegroupbycityorderbydatede
MySQL中,如何使用SQL语句来对表中某一个字段进行重命名呢?我们将使用altertable这一SQL语句。重命名字段的语法为:altertablechang
题目:请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续,判断第二个字母。程序分析:用情况语句比较好,如果第一个字母一样,则判断用情况语句或