面试常见算法题

1、抢红包算法

参考链接

 二倍均值法实现的抢红包算法的代码(以下代码由chatGPT生成)

// 抢红包方法
function grabRedPacket(totalAmount, totalPeople) {
  // 用于存储红包金额
  let redPackets = [];
  // 剩余金额
  let remainAmount = totalAmount * 100;
  // 剩余人数
  let remainPeople = totalPeople;
  // 生成随机数,模拟每个红包的金额
  for (let i = 0; i < totalPeople; i++) {
    let randomAmount;
    if (i < totalPeople - 1) {
      // 生成随机数,保证最小金额为0.01元
      randomAmount = Math.floor(Math.random() * (remainAmount / remainPeople * 2 - 1) + 1);
      randomAmount = Math.min(randomAmount, remainAmount - (totalPeople - i - 1));
      remainAmount -= randomAmount;
      remainPeople--;
    } else {
      // 最后一次生成的随机数直接设置为剩下的金额
      randomAmount = remainAmount;
    }
    redPackets.push(randomAmount / 100);
  }
  return redPackets;
}


// 抢红包示例
let totalAmount = 1;
let totalPeople = 100;
console.log(grabRedPacket(totalAmount, totalPeople));

2、二分查找算法

参考链接

以下代码由chatGPT生成

class Node {
  constructor(value, left = null, right = null) {
    this.value = value;
    this.left = left;
    this.right = right;
  }
}

class BinaryTree {
  constructor(root = null) {
    this.root = root;
  }

  lookup(value) {
    return this.lookupNode(this.root, value);
  }

  lookupNode(node, value) {
    if (!node) return false;
    if (node.value === value) return true;

    if (value < node.value) {
      return this.lookupNode(node.left, value);
    } else {
      return this.lookupNode(node.right, value);
    }
  }
}

const tree = new BinaryTree(new Node(10, new Node(5), new Node(15)));
console.log(tree.lookup(10));  // outputs: true
console.log(tree.lookup(5));   // outputs: true
console.log(tree.lookup(15));  // outputs: true
console.log(tree.lookup(20));  // outputs: false

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值