/// <summary> /// 等级换算成图标分布 /// 以QQ的形式计算 /// 2^(2*0) /1 /// 2^(2*1) /4 /// 2^(2*2) /16 /// 2^(2*3) /64 /// </summary> /// <param name="target">目标等级</param> /// <param name="x">计算底数</param> /// <param name="y">最高多少次幂</param> /// <returns></returns>
public IEnumerable<short> A(double target, double x, int y) { if (y < 1 || target <= 0 || x < 1) { return new short[] { 1 }; } var r = new short[y + 1]; for (int i = y; i > 0; i--) { double a = Math.Pow(x, i * 2); r[i] = (short)(target / a); target -= r[i] * a; } r[0] = (short)target; return r; }
思路就是这个等级去减每一个标志性等级(4,16,64...)的积分乘积。然后记录总等级/每一个标志性等级 ,这个结果就是多少个图案(皇冠,太阳...).从最大往小的图案算,减到最后就是多少个一级的图案(星星)
如果每一个标志性等级不是按Math.Pow(x, i * 2)算的话,把这个值公式换成别的应该就可以。
A(LV,2,4)
参考链接:
http://www.cnblogs.com/gzhnan/archive/2005/05/27/163466.html