字节算法题

手机号转base64编码

 public static void main(String[] args) {
        getBase64 getbase64 = new getBase64();
        long i = Long.parseLong("100");
        String str = getbase64.telToBase64(i);
        System.out.println( str);
    }

}

class getBase64{
    public String telToBase64(long lng){
        String base64[] =  {"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",
                "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",
                "0","1","2","3","4","5","6","7","8","9","+","/"};
        String str = new String();
        String res= new String();
        int i,j;
        i = (int)(lng/64);
        j = (int)(lng%64);
        res=base64[j];
        while(i>0){
            j = i%64;
            i = i/64;
            str = base64[j];
            res= str + res;
        }
        return res;
    }
}

输出:Bk

100=64(B)*1+36(k)
在这里插入图片描述

字符串找子串

给定m个不重复的字符 [a, b, c, d],以及一个长度为n的字符串tbcacbdata,问能否在这个字符串中找到一个长度为m的连续子串,使得这个子串刚好由上面m个字符组成,顺序无所谓,返回任意满足条件的一个子串的起始位置,未找到返回-1。比如上面这个例子,acbd,3。本题的子串需要满足长度为m,字符不重复,可以使用长为m的滑动窗口遍历字符串,窗口内每个字符都要出现一次,如果符合条件,就返回窗口起始位置。

class Solution {
    public int checkInclusion(char[] ch,String s) {
        int n = s.length();
        int m =ch.length;
        if(m>n) return -1;
        for(int i=0;i<n-m;i++){
            if(checkEqual(ch,s.substring(i,i+m))){
                return i;
            }
        }
        return -1;
    }
    public boolean checkEqual(char[] ch,String s){
        for(int i=0;i<ch.length;i++){
            if(s.indexOf(ch[i])==-1){
                return false;
            }
        }
        return true;
    }

假设我们要发一个随机红包,分成n份。首先,我们需要确定红包的总金额,可以使用一个随机数生成器生成一个随机的总金额。然后,我们需要保证每份红包的金额是随机的且总和等于总金额。 一个简单的方法是先生成n-1个不重复的随机数(可以用洗牌算法或者选择排序算法),这些随机数将作为切割点。然后,我们按照这些切割点将总金额分割成n份。最后,将最后一份红包的金额设为总金额减去前n-1份红包的金额之和。 具体算法如下: 1. 生成一个随机的总金额totalAmount。 2. 初始化一个数组cuts,长度为n-1。 3. 使用洗牌算法或者其它随机算法,生成n-1个不重复的随机数并赋值给cuts。可以使用一个标志数组来避免重复的切割点。 4. 将cuts数组排序,确保切割点按照从小到大的顺序排列。 5. 初始化一个数组shares,长度为n。 6. 使用循环,将shares[0]设为cuts[0],将shares[n-1]设为totalAmount减去shares[0]到shares[n-2]的和。 7. 使用循环,将shares[i]设为cuts[i]-cuts[i-1],其中1<=i<=n-2。 8. 返回数组shares,即为分割后的每份红包金额。 注意,这个算法会确保每份红包的金额是随机的,但不保证每份红包的金额分布是均匀的。如果需要均匀分布的红包金额,可以在第3步中使用选择排序算法,并将切割点划分得更加细致,从而增加金额的差异性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值