为了账号安全,请及时绑定邮箱和手机立即绑定

javascript实现数据结构中的队列结构

标签:
JavaScript
function Queen() {
    this.dataStore = [];
    this.enqueue = enqueue;
    this.dequeue = dequeue;
    this.front = front;
    this.back = back;
    this.toString = toString;
    this.empty = empty;
}
//enqueue方法向队尾添加一个元素
function enqueue(element) {
    this.dataStore.push(element);
}
//dequeue方法删除队首的元素
function dequeue() {
    return this.dataStore.shift();
}
//读取队首的元素
function front() {
    return this.dataStore[0];
}
//读取队尾的元素
function back() {
    return this.dataStore[this.dataStore.length - 1];
}
//toString方法
function toString() {
    let str = '';
    for (let i = 0; i < this.dataStore.length; i++) {
        str += this.dataStore[i] + '\n';
    }
    return str;
}
//判断队列是否为空
function empty() {
    if (this.dataStore.length == 0) {
        return true;
    } else {
        return false;
    }
}
//判断队列是否为空
function empty() {
    if (this.dataStore.length == 0) {
        return true;
    } else {
        return false;
    }
}
//基数排序
function distribute(nums, queues, n, digit) {
    for (var i = 0; i < n; i++) {
        if (digit == 1) {
            queues[nums[i] % 10].enqueue(nums[i]);
        } else {
            queues[Math.floor(nums[i] / 10)].enqueue(nums[i]);
        }
    }
}
//从队列中收集数字
function collect(queues, num) {
    let i = 0;
    for (let digit = 0; digit < 10; digit++) {
        while (!queues[digit].empty()) {
            nums[i++] = queues[digit].dequeue();
        }
    }
}
//返回队列的字符串
function dispArray(arr) {
    let str = '';
    for (let i = 0; i < arr.length; i++) {
        str += arr[i] + " ";
    }
    print(str);
}
let queues = [];
for (let i = 0; i < 10; ++i) {
    queues[i] = new Queue();
}
let nums = [];
for (let i = 0; i < 10; i++) {
    nums[i] = Math.floor(Math.random() * 100);
}
print("Befor radix sort: ");
dispArray(nums);
distribute(nums, queues, 10, 1);
collect(queues, nums);
distribute(nums, queues, 10, 10);
collect(queues, nums);
print('\n\n After radix sort: ');
dispArray(nums);


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消