算法刷题

  1. https://exercise.acmcoder.com/online/online_judge_ques?ques_id=9579&konwledgeId=137
    大学的同学来自全国各地,对于远离家乡步入陌生大学校园的大一新生来说,碰到老乡是多么激动的一件事,于是大家都热衷于问身边的同学是否与自己同乡,来自新疆的小赛尤其热衷。但是大家都不告诉小赛他们来自哪里,只是说与谁是不是同乡,从所给的信息中,你能告诉小赛有多少人确定是她的同乡吗?
    在这里插入图片描述
<script>
  var N, M;
  var  s=[],count=0,j=1
  for(let i=0;i<1000;i++)   s[i]=0
  while ((N=readInt()) != null && (M=readInt()) != null) {
  for (let i=0; i<M; i++) {
      let a = readInt();
      let b = readInt();
      let c = readInt();
      if(c){
          var min=a<b?a:b  
          var max=a>b?a:b 
          while(s[min]){  
              min=s[min] 
          }
          s[min]=max
       }

  }
  while(s[j]){
      j=s[j]
      count++
  }
  for(let i=0;i<1000;i++)   s[i]=0
  print(count)
  // M行读取完了,就又要开始下一组了,去while那里。
  }
    </script>
  1. 看到一个非常有意思的解法
    在这里插入图片描述
// 这是普通解法
function removeWithoutCopy(arr, item) {
    for(var i=arr.length-1;i>=0;i--){
        if(arr[i]==item){
            arr.splice(i,1)
        }
    }
    return arr
}
// 有意思的解法
function removeWithoutCopy(arr, item) {
    var len=arr.length;
    for(var i=0;i<len;i++){
        if(arr[0]!==item){
            arr.push(arr[0])
        }
        arr.shift()
    }
    return arr
}

3.小小一个题目,居然有这么多的解法在这里插入图片描述

//利用slice
function truncate(arr) {
    return arr.slice(0,-1);
}
//利用filter
function truncate(arr) {
    return arr.filter(function(v,i,ar) {
        return i!==ar.length-1;
    });
}
//利用push.apply+pop
function truncate(arr) {
    var newArr=[];
    [].push.apply(newArr, arr);
    newArr.pop();
    return newArr;
}
//利用join+split+pop    注意!!!:数据类型会变成字符型
function truncate(arr) {
    var newArr = arr.join().split(',');
    newArr.pop();
    return newArr;
}
//利用concat+pop
function truncate(arr) {
    var newArr = arr.concat();
    newArr.pop();
    return newArr;
}
//普通的迭代拷贝
function truncate(arr, item) {
    var newArr=[];
    for(var i=0;i<arr.length-1;i++){
        newArr.push(arr[i]);
    }
    return newArr;
}

4.在这里插入图片描述

function duplicates(arr) {
    var result=[];
    var len=arr.length;
    for(var i=0;i<len;i++){
        if(arr.indexOf(arr[i],i+1)!=-1 && result.indexOf(arr[i])==-1){
            result.push(arr[i]);
        }
    }
    return result
}
  1. 在这里插入图片描述
    在这里插入图片描述
function callIt(fn) {
    //将arguments转化为数组后,截取第一个元素之后的所有元素
    var args = Array.prototype.slice.call(arguments,1);
    //调用fn
    var result = fn.apply(null,args);
    return result;
}

在这里插入图片描述
解法1
通过num.toString(2)能直接将num转换为2进制数格式的字符串,利用下标就能将对应值取出来。题目返回的数字是从右往左,因此下标为倒数。

function valueAtBit(num, bit) {
  var s = num.toString(2);
     return s[s.length - bit];
 }

解法2

function valueAtBit(num, bit) {
    return (num >> (bit -1)) & 1;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhangpaopao0609

看星空看日落不如看我的眼眸

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值