JavaScript_牛客网_编程初学者入门训练(71-80题解)

编程初学者入门训练第71-80题解答(js)

本文章尽量用简洁的代码去完成题目要求,话不多说,上代码(因为js语言的限制,所以有些题是骚操作,娱乐而已),后期会不断更新的。
注:有些题找不见了,把有的题写了一下。
代码链接: 编程初学者入门71-80T代码.

71.新年快乐

题目描述:新年到来,输出信息迎接新年。
输入描述:无。
输出描述:Happy New Year2019

console.log('Happy New Year*2019*')

73.挂科危险

题目描述:KiKi想知道这学期他的学习情况,BoBo老师告诉他这学期挂的科目累计的学分,根据所挂学分,判断KiKi学习情况,10分以上:很危险(Danger++),4-9分:危险(Danger),0-3:Good。
输入描述:一行,一个整数(0~30),表示KiKi挂的科目累计的学分。
输出描述:一行,根据输入的挂科学分,输出相应学习情况(Danger++,Danger,Good)。

let n = parseInt(readline())
if(n>=0&& n<=30){
    if(n>=10){
        console.log('Danger++')
    }else if(n>=4){
        console.log('Danger')
    }else{
        console.log('Good')
    }
}

74.HTTP状态码

题目描述:KiKi访问网站,得到HTTP状态码,但他不知道什么含义,BoBo老师告诉他常见HTTP状态码:200(OK,请求已成功),202(Accepted,服务器已接受请求,但尚未处理。)400(Bad Request,请求参数有误),403(Forbidden,被禁止),404(Not Found,请求失败),500(Internal Server Error,服务器内部错误),502(Bad Gateway,错误网关)。
输入描述:多组输入,一行,一个整数(100~600),表示HTTP状态码。
输出描述:针对每组输入的HTTP状态,输出该状态码对应的含义,具体对应如下:
200-OK
202-Accepted
400-Bad Request
403-Forbidden
404-Not Found
500-Internal Server Error
502-Bad Gateway

while(line=readline()){
    let lines = line.split(/[\n]/);
    for(let i =0;i<lines.length;i++){
        let n = parseInt(lines[i]);
        if(n>=100&&n<=600){
            if(n==200){
                console.log('OK')
            }else if(n==202){
                console.log('Accepted')
            }else if(n==400){
                console.log('Bad Request')
            }else if(n==403){
                console.log('Forbidden')
            }else if(n==404){
                console.log('Not Found')
            }else if(n==500){
                console.log('Internal Server Error')
            }else if(n==502){
                console.log('Bad Gateway')
            }   
        }
    }
}

75.数字三角形

题目描述:KiKi学习了循环,BoBo老师给他出了一系列打印图案的练习,该任务是打印用数字组成的数字三角形图案。
输入描述:多组输入,一个整数(3~20),表示数字三角形边的长度,即数字的数量,也表示输出行数。
输出描述:针对每行输入,输出用数字组成的对应长度的数字三角形,每个数字后面有一个空格。

while(line=readline()){
    let lines = line.split(/[\n]/);
    for(let i =0;i<lines.length;i++){
        let n = parseInt(lines[i]);
        if(n>=3&&n<=20){
            for(let i=1;i<=n;i++){
                let str = ''
                for(let j=1;j<=i;j++){
                    if(j<i){
                        str += j+' '
                    }else{
                        str += j
                    }
                }
                console.log(str)
            }
        }
    }
}

76.公务员面试

题目描述:公务员面试现场打分。有7位考官,从键盘输入若干组成绩,每组7个分数(百分制),去掉一个最高分和一个最低分,输出每组的平均成绩。
输入描述:一行,输入7个整数(0~100),代表7个成绩,用空格分隔。
输出描述:一行,输出去掉最高分和最低分的平均成绩,小数点后保留2位,每行输出后换行。

let str = readline().split(' ')
let arr = []
let sum = 0;
for(let i=0;i<7;i++){
    arr.push(Number(str[i]));
    sum += Number(str[i]);
}
arr.sort(function(a,b){return a-b});
sum = sum - arr[0] -arr[6];
let ave = (sum/5).toFixed(2);
console.log(ave)

77.有序序列插入一个数

题目描述:有一个有序数字序列,从小到大排序,将一个新输入的数插入到序列中,保证插入新数后,序列仍然是升序。
输入描述:第一行输入一个整数(0≤N≤50)。
第二行输入N个升序排列的整数,输入用空格分隔的N个整数。
第三行输入想要进行插入的一个整数。
输出描述:输出为一行,N+1个有序排列的整数。

let n = parseInt(readline())
let str = readline().split(' ')
let m = parseInt(readline())
if(m<Number(str[0])){
    str.unshift(m)
    console.log(str.join(' '))
}else if(m>Number(str[str.length-1])){
    str.push(m)
    console.log(str.join(' '))
}else{
    for(var i=0;i<str.length-1;i++){
        if(m>=Number(str[i])&&m<Number(str[i+1])){
            let b= str.splice(i+1,0,m);
            break;
        }
    }
    console.log(str.join(' '))
}

78.筛选法求素数

题目描述:用筛选法求n以内的素数。筛选法求解过程为:将2~n之间的正整数放在数组内存储,将数组中2之后的所有能被2整除的数清0,再将3之后的所有能被3整除的数清0 ,以此类推,直到n为止。数组中不为0 的数即为素数。
输入描述:多组输入,每行输入一个正整数(不大于100)。
输出描述:针对每行输入的整数n,输出两行,第一行,输出n之内(包括n)的素数,用空格分隔,第二行,输出数组中2之后0 的个数。每行输出后换行。

while(line=readline()){
    let lines = line.split(/[\n]/);
    for(let i =0;i<lines.length;i++){
        let str = ''
        let count = 0
        let N = parseInt(lines[i]);
        for(let j=2;j<=N;j++){
            if(is_prime(j)){
                str += j+' ';
                count++;
            }
        }
        let p = str.substring(0,str.length-1);
        let s = N - count -1;
        console.log(p+'\n'+s)
    }
}
function is_prime(n){
    let num = Math.sqrt(n);
    for(let i=2;i<Math.floor(num)+1;i++){
        if(n%i==0) {
            return false;
        }
    }
    return true;
}

79.图像相似度

题目描述:给出两幅相同大小的黑白图像(用0-1矩阵)表示,求它们的相似度。若两幅图像在相同位置上的像素点颜色相同,则称它们在该位置具有相同的像素点。两幅图像的相似度定义为相同像素点数占总像素点数的百分比。
输入描述:第一行包含两个整数m和n,表示图像的行数和列数,用单个空格隔开。1≤m≤100, 1≤n≤100。之后m行,每行n个整数0或1,表示第一幅黑白图像上各像素点的颜色,相邻两个数用单个空格隔开。之后m行,每行n个整数0或1,表示第二幅黑白图像上各像素点的颜色,相邻两个数用单个空格隔开。
输出描述:一个实数,表示相似度(以百分比的形式给出),精确到小数点后两位。

let str = readline().split(' ')
let m = parseInt(str[0])
let n = parseInt(str[1])
let arr1 = []
let arr2 = []
let count = 0;
for(let i=0;i<m;i++){
    let q = readline().split(' ')
    arr1[i] = []
    for(let j=0;j<n;j++){
        arr1[i].push(parseInt(q[j]))
    }
}
for(let i=0;i<m;i++){
    let q = readline().split(' ')
    arr2[i] = []
    for(let j=0;j<n;j++){
        arr2[i].push(parseInt(q[j]))
    }
}
for(let i=0;i<m;i++){
    for(let j=0;j<n;j++){
        if(arr1[i][j]==arr2[i][j]){
            count++;
        }
    }
}
let res = (count*100/(m*n)).toFixed(2)
console.log(res)

80.登录验证

题目描述:有个软件系统登录的用户名和密码为(用户名:admin,密码:admin),用户输入用户名和密码,判断是否登录成功。
输入描述:多组测试数据,每行有两个用空格分开的字符串,第一个为用户名,第二个位密码。
输出描述:针对每组输入测试数据,输出为一行,一个字符串(“Login Success!”或“Login Fail!”)。

while(line=readline()){
    let lines = line.split(/[\n]/);
    for(let i =0;i<lines.length;i++){
        let r = lines[i].split(' ');
        let a = r[0];
        let b = r[1];
        if(a==b&&a=='admin'){
            console.log("Login Success!")
        }else{
            console.log("Login Fail!")
        }
    }
}

惊人,惊情,惊梦,惊心,怆然暗惊后再看时,这些年的风风雨雨,恍如隔世。
未完待续,Loading…

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值