zoukankan      html  css  js  c++  java
  • 【JavaScript】7-30 字符串的冒泡排序 (20分)

    题目:

    我们已经知道了将N个整数按从小到大排序的冒泡排序法。本题要求将此方法用于字符串序列,并对任意给定的K(<N),输出扫描完第K遍后的中间结果序列。

    输入格式:

    输入在第1行中给出N和K(1K<N100),此后N行,每行包含一个长度不超过10的、仅由小写英文字母组成的非空字符串。

    输出格式:

    输出冒泡排序法扫描完第K遍后的中间结果序列,每行包含一个字符串。 

    输入样例:

    6 2
    best
    cat
    east
    a
    free
    day

    输出样例:

    best
    a
    cat
    day
    east
    free

    思路:

    参考整数冒泡排序法,不同的是输入行数要根据第一行的N,需要先读取到N值。

    在JavaScript中字符串的大小可以直接用【>】或【<】进行比较,JS解释器会把字符串转换为ASCII码逐个字符依次比较。

    JavaScript代码:

    var readline = require('readline');
    
    //创建一个readline接口实例
    var readlineTest = readline.createInterface({    
        input: process.stdin,
        output: process.stdout    
    });
    
    var tempArray=[];    //创建数组来存储每一行的数据
    var tempArrayIndex=0;//初始化数组的索引
    
    readlineTest.on('line', function(line){
        
        //将每一行的内容添加至数组tempArray
        tempArray[tempArrayIndex]=line;
        tempArrayIndex++;
        
        var line1 = tempArray[0].split(' ')
        var N = parseInt(line1[0])
        var K = parseInt(line1[1])
    
        var strArr = []
        for (let i = 1; i <= N; i++) {
            strArr.push( tempArray[i] )
        }
        //当已输入的行数达到最大输入的行数时,结束readline.Interface实例
        if (tempArray.length == N + 1) {
            var ret = sort(N, K,strArr)        
            console.log(ret)
            readlineTest.close();
        }
        
    });
    
    //当readlineTest执行'close'命令时,输入流关闭,程序结束。
    readlineTest.on('close', function() {    
        process.exit(0);    
    });
    
    function sort(N, K, strArr) {
        
        for (let i = 0; i < K; i++) {
            var max = strArr[0]
            for (let j = 1; j < N; j++) {
                if (max > strArr[j]) {
                    strArr[j - 1] = strArr[j]
                    strArr[j] = max
                } else {
                    max = strArr[j]
                }
            }
        }
    
        var newarr = strArr.join('
    ')
    
        return newarr
    }
  • 相关阅读:
    bShare一个强大的网页分享插件
    免费软件,到底是谁在获益?
    波西的小球——优化日志
    CSDN无故删除东西,强烈抗议 枯木
    网站排障分析常用的命令 枯木
    KVM在线迁移(动态迁移) 枯木
    RHEL6 KVM安装备忘 枯木
    MySQL备份和恢复具体实施(上) 枯木
    Nginx支持php相关配置 枯木
    关于RHEL6中ulimit的nproc限制 枯木
  • 原文地址:https://www.cnblogs.com/moonskies/p/14338344.html
Copyright © 2011-2022 走看看