算法:QQ等级换算成皇冠太阳星星月亮

  1. 云栖社区>
  2. 博客>
  3. 正文

算法:QQ等级换算成皇冠太阳星星月亮

amiba.org 2015-02-27 14:07:00 浏览321
展开阅读全文

 

/// <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

 

网友评论

登录后评论
0/500
评论
amiba.org
+ 关注