C#根據(jù)權(quán)重抽取隨機數(shù)
(游戲中一個很常見的簡單功能,比如抽卡抽獎抽道具,或者一個怪物有多種攻擊動作,按不同的權(quán)重隨機出個攻擊動作等等……)
假如有三種物品 A、B、C,對應(yīng)的權(quán)重分別是A(50),B(20),C(30)
那么,如果從 0-100中抽取一個隨機數(shù),可以這樣理解:
- 在0-50之間時,將得到A
- 在50-70之間時,得到B
- 在70-100之間時,得到C
下面是實現(xiàn)代碼。
string[] items = new string[] { "A", "B", "C" };
int[] weight = new int[] { 50, 20, 30 };
string WeightRandom()
{
//先算出所有權(quán)重的總和
int sum = 0;
foreach (int w in weight)
sum += w;
//Roll隨機數(shù), 區(qū)間是從0到總和
int random = Random.Range(0, sum);
int currRange = 0;
//遍歷每個item對應(yīng)到區(qū)間。如果結(jié)果在此區(qū)間內(nèi),返回此item。
for (int i = 0; i < items.Length; i++)
{
currRange += weight[i];
if (random < currRange)
{
Debug.Log(string.Format("隨機數(shù):【{0}】. 結(jié)果:【{1}】", random.ToString(), items[i]));
return items[i];
}
}
return null;
}測試一下:運行20次

當(dāng)然,這里使用的權(quán)重50+20+30 =100 ,只是為了方便理解。
并非權(quán)重的總和一定要等于100。多少都是可以的。隨機數(shù)的選取范圍只需要是(0,總和)即可。
到此這篇關(guān)于C#根據(jù)權(quán)重抽取隨機數(shù)的文章就介紹到這了,更多相關(guān)C#根據(jù)權(quán)重抽取隨機數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C#模擬鏈表數(shù)據(jù)結(jié)構(gòu)的實例解析
這篇文章主要介紹了C#模擬鏈表數(shù)據(jù)結(jié)構(gòu)的實例解析,包括隊雙向鏈表的模擬方法,例子中隊鏈表的操作也有很好的說明,需要的朋友可以參考下2016-04-04
C#探秘系列(四)——GetHashCode,ExpandoObject
這篇繼續(xù)分享下GetHashCode和ExpandoObject這兩個比較好玩的方法。2014-05-05
C#使用IronPython庫調(diào)用Python腳本
這篇文章介紹了C#使用IronPython庫調(diào)用Python腳本的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-06-06
C#?線程切換后上下文都去了哪里(.NET高級調(diào)試分析)
總會有一些朋友問一個問題,在 Windows 中線程做了上下文切換,請問被切的線程他的寄存器上下文都去了哪里?這個問題其實比較底層,如果對操作系統(tǒng)沒有個體系層面的理解以及做過源碼分析,其實很難說明白,這篇我們就從.NET高級調(diào)試的角度分析,需要的朋友可以參考下2023-12-12

