用户邀请码的生成方法

版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_33563706/article/details/51897558
最近由于现公司某些原因不得不重新投入到找工作的浪潮中。在面试过程中也遇到过一些比较有趣的面试题。可能当时没有想到,回来后自己又思考了下。题目一:已知一个用户的ID(ID是长整形)根据用户ID给用户生成一个唯一的邀请码(邀请码范围([a-z0-9])?代码实现!

当时思考的几种方案都比较简单:

<?php
    function createCode($userId)
    {
        //方案一:
        $currentTime = time();
        $code = "{$userId}{$currentTime}";
        return $code;

        //方案二:

        while(true){
            //获取一个随机字符串
            $code = getRandString(8);
            //判断该字符串是否存在
            if( ! checkExists($code))
                return $code;
        }
    }

当时想到的几种方案差不多都是按照这两种演变而来。

两种方案的缺点:

方案一:字符串长度过长,邀请码一般都是需要在用户之间进行传递。过长不利于用户记住。而且不优雅。呵呵。

方案二:每次生成随机字符串都需要去数据库中查找判断是否已经存在了。当用户基数庞大时,势必会影响效率。对于追求效率的开发者来说。这种方案也不是最佳的!


新的方案:

字符a-z0-9刚好是36个。是否可以考虑直接将用户ID转换成一个36进制的数呢?

代码实现:

<?php
function createCode($userId)
{
    static $sourceString = [
              0,1,2,3,4,5,6,7,8,9,10,
              'a','b','c','d','e','f',
              'g','h','i','j','k','l',
              'm','n','o','p','q','r',
              's','t','u','v','w','x',
              'y','z'
            ];

    $num = $userId;
    $code = '';
    while($num)
    {
        $mod = $num % 36;
        $num = (int)($num / 36);
        $code = "{$sourceString[$mod]}{$code}";
    }
    
    //判断code的长度
    if( empty($code[4]))
        str_pad($code,5,'0',STR_PAD_LEFT);

    return $code;
}

与前两种方案相比较新的方案弥补了前两种方案的缺点,同时保证同一个用户重复生成邀请码时不变的优点,当然这种实现方式还需要结合具体的需求来具体区别对待了。




展开阅读全文

没有更多推荐了,返回首页