<address id="ousso"></address>
<form id="ousso"><track id="ousso"><big id="ousso"></big></track></form>
  1. java語言

    Javascript中常見的邏輯題及解決方法

    時間:2025-01-18 06:57:55 java語言 我要投稿
    • 相關推薦

    Javascript中常見的邏輯題及解決方法

      本文是百分網小編搜索整理的關于Javascript中常見的邏輯題及解決方法,需要的朋友們一起看看吧!想了解更多相關信息請持續關注我們應屆畢業生考試網!

      一、統計數組 arr 中值等于 item 的元素出現的次數

      function count(arr, item) {

      var count = 0;

      arr.forEach(function(e){

      //e為arr中的每一個元素,與item相等則count+1

      e == item ? count++ : 0;

      });

      return count;

      }

      function count(arr, item) {

      return arr.filter(function(a){

      return (a==item);

      }).length

      }

      function count(arr, item) {

      var res;

      return (res = arr.toString().match(new RegExp("//b"+item+"//b","g")))?res.length:0;

      }

      function count(arr, item) {

      var count = 0;

      arr.map(function(a) {

      if(a === item) {

      count++;

      }

      });

      return count;

      }

      二、為數組 arr 中的每個元素求二次方。不要直接修改數組 arr,結果返回新的數組

      function square(arr) {

      return arr.map(function(item,index,array){

      return item*item;

      })

      }

      function square(arr) {

      //聲明一個新的數組存放結果

      var a = [];

      arr.forEach(function(e){

      //將arr中的每一個元素求平方后,加入到a數組中

      a.push(e*e);

      });

      return a;

      }

      function square(arr) {

      //復制一個arr數組

      var newarr = arr.slice(0);

      for (var i=0;i<newarr.length;i++){

      newarr[i]= newarr[i]* newarr[i];

      }

      return newarr;

      }

      function square(arr) {

      return arr.map(function(item){

      return Math.pow(item, 2);

      })

      }

      三、將數組 arr 中的元素作為調用函數 fn 的參數

      function argsAsArray(fn, arr) {

      return fn.apply(this, arr);

      }

      function argsAsArray(fn, arr) {

      return function(para1,para2){

      return para1.apply(this,para2);

      }(fn,arr);

      }

      四、完成函數 createModule,調用之后滿足如下要求:

      1、返回一個對象

      2、對象的 greeting 屬性值等于 str1,name 屬性值等于 str2

      3、對象存在一個 sayIt 方法,該方法返回的字符串為 greeting屬性值 + ‘, ‘ +name屬性值

      function createModule(str1, str2) {

      var obj = {

      greeting : str1,

      name   : str2,

      sayIt  : function(){

      //兩個屬性前面都需要加上this

      return this.greeting+", "+this.name;

      }

      };

      return obj;

      }

      //使用構造函數法

      function createModule(str1, str2) {

      function Obj(){

      this.greeting = str1;

      this.name = str2;

      this.sayIt = function(){

      return this.greeting + ', ' + this.name;

      };

      }

      return new Obj();

      }

      //構造函數與原型組合

      function createModule(str1, str2) {

      function CreateMod(){

      this.greeting = str1;

      this.name = str2;

      }

      CreateMod.prototype.sayIt = function(){

      return this.greeting + ', ' + this.name;

      }

      return new CreateMod();

      }

      五、已知 fn 為一個預定義函數,實現函數 curryIt,調用之后滿足如下條件:

      1、返回一個函數 a,a 的 length 屬性值為1(即顯式聲明 a 接收一個參數)

      2、調用 a 之后,返回一個函數 b, b 的 length 屬性值為 1

      3、調用 b之后,返回一個函數 c, c 的 length 屬性值為 1

      4、調用 c 之后,返回的結果與調用 fn 的返回值一致

      5、fn的參數依次為函數 a, b, c 的調用參數

      輸入例子:

      var fn = function (a, b, c) {return a + b + c}; curryIt(fn)(1)(2)(3);

      function curryIt(fn) {

      //獲取fn參數的數量

      var n = fn.length;

      //聲明一個數組args

      var args = [];

      //返回一個匿名函數

      return function(arg){

      //將curryIt后面括號中的參數放入數組

      args.push(arg);

      //如果args中的參數個數小于fn函數的參數個數,

      //則執行arguments.callee(其作用是引用當前正在執行的函數,這里是返回的當前匿名函數)。

      //否則,返回fn的調用結果

      if(args.length < n){

      return arguments.callee;

      }else return fn.apply("",args);

      }

      }

      function curryIt(fn) {

      return function a(xa){

      return function b(xb){

      return function c(xc){

      return fn.call(this,xa,xb,xc);

      };

      };

      };

      }

      六、數組中輸出元素位置

      function indexof(arr,item){

      for(var i = 0,len = arr.length;i<len;i++){

      var ite = arr[i];

      if(ite == item){

      console.log(ite == item);

      return i;

      }else{

      return -1;

      }

      }

      }

      function indexof(arr,item){

      return arr.indexOf(item);

      }

      七、數組求和

      function sum(arr) {

      return eval(arr.join("+"));

      };

      八、刪除給定元素

      function remove(arr, item) {

      for(var i=0, m=arr.length, res=[]; i<m; i++){

      if(item === arr[i]) continue;

      else res.push(arr[i]);

      }

      return res;

      }

      function remove(arr, item) {

      var newA=arr.slice(0);

      for(var i=newA.indexOf(item);i>-1;i=newA.indexOf(item)){

      newA.splice(i,1);

      }

      return newA;

      }

    【Javascript中常見的邏輯題及解決方法】相關文章:

    JavaScript中的邏輯判斷符--與!介紹10-11

    GMAT考試邏輯題的常見錯誤10-22

    GMAT考試邏輯題常見的三大規律201708-12

    Java筆試邏輯題10-22

    Dreamweaver中JavaScript行為操作08-23

    托福閱讀考試常見邏輯解讀09-30

    GMAT邏輯題練習及答案07-30

    GMAT邏輯真題訓練10-13

    常見電腦故障及解決方法09-11

    <address id="ousso"></address>
    <form id="ousso"><track id="ousso"><big id="ousso"></big></track></form>
    1. 日日做夜狠狠爱欧美黑人