码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2015-02-27 14:56:41      阅读:136      评论:0      收藏:0      [点我收藏+]

标签:

 

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

 

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

标签:

原文地址:http://www.cnblogs.com/zeusro/p/4303187.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!