<delect id="sj01t"></delect>
  1. <em id="sj01t"><label id="sj01t"></label></em>
  2. <div id="sj01t"></div>
    1. <em id="sj01t"></em>

            <div id="sj01t"></div>
            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

            <delect id="sj01t"></delect>
            1. <em id="sj01t"><label id="sj01t"></label></em>
            2. <div id="sj01t"></div>
              1. <em id="sj01t"></em>

                      <div id="sj01t"></div>
                      黄色视频在线观看