js中字元和數組一些基本演算法題

来源:http://www.cnblogs.com/zzllx/archive/2016/08/13/5769154.html
-Advertisement-
Play Games

最近在刷 fcc的題,跟升級打怪一樣,一關一關的過,還挺吸引我的。今天抽時間把 Basic Algorithm Scritping 這部分題做了,根據一些提示,還是比較簡單的。有些題的處理方式 方法,我想值得借鑒。比如在項目中有時候要處理一個字元,如果想不到一些相關的方法,還挺費事的,所以,在此記錄 ...


    最近在刷 fcc的題,跟升級打怪一樣,一關一關的過,還挺吸引我的。今天抽時間把 Basic Algorithm Scritping  這部分題做了,根據一些提示,還是比較簡單的。有些題的處理方式 方法,我想值得借鑒。比如在項目中有時候要處理一個字元,如果想不到一些相關的方法,還挺費事的,所以,在此記錄下來,如果以後遇到一些字元或者數組處理,可以來翻翻這篇文章,希望以此得到一些提示而不是去翻文檔。

  看到此博文的博友,有更好更簡單的代碼或者好的想法,請留言交流(我一直覺得只有學習別人的優秀代碼才能進步更快,思維更靈活)。對於初學者,不看代碼自己試著做一遍唄。(以下題目都不用考慮參數類型,嚴格來說應該對參數類型做一個判斷,eg:typeOf(arg) === number)

1.Reverse a String


翻轉字元串

先把字元串轉化成數組,再藉助數組的reverse方法翻轉數組順序,最後把數組轉化成字元串。

你的結果必須得是一個字元串

function reverseString(str) {
  str = str.split('').reverse().join('');
 
  return str;
}

reverseString("hello");
View Code

 

2.Check for Palindromes 


如果給定的字元串是迴文,返回true,反之,返回false

如果一個字元串忽略標點符號、大小寫和空格,正著讀和反著讀一模一樣,那麼這個字元串就是palindrome(迴文)。

註意你需要去掉字元串多餘的標點符號和空格,然後把字元串轉化成小寫來驗證此字元串是否為迴文。

函數參數的值可以為"racecar""RaceCar""race CAR"

function palindrome(str) {
  // Good luck!
  
  str=str.replace(/[\ |\~|\`|\!|\@|\#|\$|\%|\^|\&|\*|\(|\)|\-|\_|\+|\=|\||\\|\[|\]|\{|\}|\;|\:|\"|\'|\,|\<|\.|\>|\/|\?]/g,"");  //去除標點符號,這是我百度的,js的正則不是很熟悉
  str = str.replace(/\s+/g);
  str = str.toLowerCase();
  var arr = str.split('');
      arr = arr.reverse();
   var str1 = arr.join("");
  if(str === str1){
  return true;}
  return false;
}



palindrome("eye");

/*

palindrome("eye") 應該返回一個布爾值
palindrome("eye") 應該返回 true.
palindrome("race car") 應該返回 true.
palindrome("not a palindrome") 應該返回 false.
palindrome("A man, a plan, a canal. Panama") 應該返回 true.
palindrome("never odd or even") 應該返回 true.
palindrome("nope") 應該返回 false.
palindrome("almostomla") 應該返回 false.
palindrome("My age is 0, 0 si ega ym.") 應該返回 true.
palindrome("1 eye for of 1 eye.") 應該返回 false.
palindrome("0_0 (: /-\ :) 0-0") 應該返回 true.



*/
View Code

 

3.Title Case a Sentence


確保字元串的每個單詞首字母都大寫,其餘部分小寫。(eg:titleCase("I'm a little tea pot") 應該返回 "I'm A Little Tea Pot".   titleCase("sHoRt AnD sToUt") 應該返回 "Short And Stout".)

/*這題很簡單,主要是要明白  split() 是把字元串分割成數組 
join() 是把 數組變成字元串  
toLowerCase() toUpperCase() 大小寫轉換,註意,只對字母有效,其他字元(eg:/,!@)無效
*/

function titleCase(str) {
 str = str.split(" ");//按照空格把字元串分割成數組
    for (var i = 0; i < str.length; i++) {
        str[i] = str[i].toLowerCase();
        str[i] = str[i].substring(0, 1).toUpperCase() + str[i].substring(1);
    }
    return str.join(" ");//通過空格把數組連接成字元串
}

titleCase("I'm a little tea pot");
View Code

4.Confirm the Ending


檢查一個字元串(str)是否以指定的字元串(target)結尾。

如果是,返回true;如果不是,返回false。例如:confirmEnding("Bastian", "n") 應該返回 true.  confirmEnding("Connor", "n") 應該返回 false.  confirmEnding("Walking on water and developing software from a specification are easy if both are frozen", "specification") 應該返回 false.

function confirmEnding(str, target) {
  // "Never give up and good luck will find you."
  // -- Falcor
  
  return str.substr(str.length-target.length) == target ? true:false;
}

confirmEnding("Bastian", "n");
confirmEnding("He has to give me a new name", "na");
/*
confirmEnding("Bastian", "n") 應該返回 true.
confirmEnding("Connor", "n") 應該返回 false.
confirmEnding("Walking on water and developing software from a specification are easy if both are frozen", "specification") 應該返回 false.
confirmEnding("He has to give me a new name", "name") 應該返回 true.
confirmEnding("He has to give me a new name", "me") 應該返回 true.
confirmEnding("He has to give me a new name", "na") 應該返回 false.
confirmEnding("If you want to save our world, you must hurry. We dont know how much longer we can withstand the nothing", "mountain") 應該返回 false.
*/
View Code

5.Repeat a string repeat a string


重要的事情說3遍!

重覆一個指定的字元串 num次,如果num是一個負數則返回一個空字元串。例如:

repeat("*", 3) 應該返回"***". repeat("abc", 3) 應該返回"abcabcabc". repeat("abc", 4) 應該返回"abcabcabcabc". repeat("abc", 1) 應該返回"abc". repeat("*", 8) 應該返回"********". repeat("abc", -2) 應該返回"".

當你完成不了挑戰的時候,記得開大招'Read-Search-Ask'。

這是一些對你有幫助的資源:

function repeat(str, num) {
  // repeat after me
  var newstr = str;
  if(num >1){
    for(var i = 1; i< num ; i ++){
      str +=newstr;
    }
    return str;
  }else if(num == 1){
    return str;
  }else{
    return "";
  }
  
}

repeat("abc", 3);
repeat("*", 3);
View Code

6.Chunky Monkey


猴子吃香蕉可是掰成好幾段來吃哦!

把一個數組arr按照指定的數組大小size分割成若幹個數組塊。

例如:chunk([1,2,3,4],2)=[[1,2],[3,4]];

chunk([1,2,3,4,5],2)=[[1,2],[3,4],[5]];

 1 function chunk(arr, size) {
 2   // Break it up.
 3 var arr1 = [];
 4     for (var i = 0; i < arr.length; i = i + size) {
 5         var arr2 = arr;
 6         arr1.push(arr2.slice(i, i + size));
 7     }
 8     return arr1;
 9 }
10 
11 chunk(["a", "b", "c", "d"], 2);
View Code

7.Falsy Bouncer


真假美猴王!

刪除數組中的所有假值。

在JavaScript中,假值有falsenull0""undefinedNaN

當你完成不了挑戰的時候,記得開大招'Read-Search-Ask'。

這是一些對你有幫助的資源:

例如:

bouncer([7, "ate", "", false, 9]) 應該返回 [7, "ate", 9]. bouncer(["a", "b", "c"])應該返回 ["a", "b", "c"]. bouncer([false, null, 0, NaN, undefined, ""]) 應該返回 []. bouncer([1, null, NaN, 2, undefined]) 應該返回 [1, 2].
/* 
這題註意是對filter的理解,這是我最開始的代碼,寫的不是很好,沒多大參考價值
還要註意 NaN 比較。 自己不等於自己(NaN != NaN )
*/

function bouncer(arr) {
  // Don't show a false ID to this bouncer.
 var arr1 =[];
    var j = 0;
    arr.filter(function(val, index) {
        if (val === false || val === null || val === 0 || val === "" || val === undefined || val !== val) {
           arr1.push(index);
        }
    });
    var len = arr1.length;

    for(var i = 0; i < len ; i++){
          arr.splice(arr1[i]-j,1);
          j++;
    }
  return arr;
}

bouncer([7, "ate", "", false, 9]);
View Code

8.Seek and Destroy


金克斯的迫擊炮!

實現一個摧毀(destroyer)函數,第一個參數是待摧毀的數組,其餘的參數是待摧毀的值。

例如:

destroyer([1, 2, 3, 1, 2, 3], 2, 3) 應該返回 [1, 1]. destroyer([1, 2, 3, 5, 1, 2, 3], 2, 3) 應該返回 [1, 5, 1]. destroyer([3, 5, 1, 2, 2], 2, 3, 5) 應該返回 [1]. destroyer([2, 3, 2, 3], 2, 3) 應該返回 []. destroyer(["tree", "hamburger", 53], "tree", 53) 應該返回["hamburger"].

這是一些對你有幫助的資源:

function destroyer(arr) {
  // Remove all the values
  var tempArguments = arguments;
  return arr.filter(function(entry) {
    for(var i = 1; i< tempArguments.length; i++) {
      if (entry == tempArguments[i]) {
        return false;
      }
    }
    return true;
  });
}

destroyer([1, 2, 3, 1, 2, 3], 2, 3);
View Code

9.Where do I belong 


我身在何處?

先給數組排序,然後找到指定的值在數組的位置,最後返回位置對應的索引。

舉例:where([1,2,3,4], 1.5) 應該返回1。因為1.5插入到數組[1,2,3,4]後變成[1,1.5,2,3,4],而1.5對應的索引值就是1

同理,where([20,3,5], 19) 應該返回 2。因為數組會先排序為 [3,5,20]19插入到數組[3,5,20]後變成[3,5,19,20],而19對應的索引值就是2

這是一些對你有幫助的資源:

function where(arr, num) {
  // Find my place in this sorted array.
  //註意sort() 排序規則
 arr.sort(function(a,b){
      return a- b;
  });

  for(var i =0;i<arr.length;i++){
      
    if(arr[i]>num | arr[i] == num){
        
      return i;
    }
  }
  return arr.length;
}



where([5, 3, 20, 3], 5);
View Code

10.Caesars Cipher 


讓上帝的歸上帝,凱撒的歸凱撒。

下麵我們來介紹風靡全球的凱撒密碼Caesar cipher,又叫移位密碼。

移位密碼也就是密碼中的字母會按照指定的數量來做移位。

一個常見的案例就是ROT13密碼,字母會移位13個位置。由'A' ↔ 'N', 'B' ↔ 'O',以此類推。

寫一個ROT13函數,實現輸入加密字元串,輸出解密字元串。

所有的字母都是大寫,不要轉化任何非字母形式的字元(例如:空格,標點符號),遇到這些特殊字元,跳過它們。

例如:

rot13("SERR PBQR PNZC") 應該解碼為 "FREE CODE CAMP" rot13("SERR CVMMN!") 應該解碼為 "FREE PIZZA!" rot13("SERR YBIR?") 應該解碼為 "FREE LOVE?" rot13("GUR DHVPX OEBJA QBT WHZCRQ BIRE GUR YNML SBK.") 應該解碼為 "THE QUICK BROWN DOG JUMPED OVER THE LAZY FOX."

這是一些對你有幫助的資源:

function rot13(str) { // LBH QVQ VG!
    var arr = str.toUpperCase().split(" ");
    var str1 = [];
    for (var i = 0; i < arr.length; i++) {
        var arr1 = arr[i].split("");
        for (var j = 0; j < arr1.length; j++) {
            var num = arr1[j].charCodeAt();
            if (num >= 65 && num <= 90) {
                arr1[j] = num + 13 > 90 ? String.fromCharCode(64 + (num + 13 - 90)):String.fromCharCode(num + 13);  //64 + (num + 13 - 90) 要明白為什麼是64 ,
            }

        }
        str1.push(arr1.join(""));
    }
    return str1.join(" ");
}

// Change the inputs below to test
rot13("SERR PBQR PNZC");
View Code

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 集合介面 集合實現(鏈表、數組列表、散列集、樹集、隊列與雙端隊列、映射表) 集合與數組之間的轉換 演算法(排序、二分查找)。 ...
  • 一、單個controller範圍的異常處理 說明: 在controller中加入被@ExceptionHandler修飾的類即可(在該註解中指定該方法需要處理的那些異常類) 該異常處理方法只在當前的controller中起作用 二、全部controller範圍內起作用的異常處理(全局異常處理) 1、 ...
  • 為什麼需要非同步?why?來看一段代碼。 問題1: for(var i=0;i<100000;i++){ } alert('hello world!!!'); 這段代碼的意思是執行100...次後再執行alert,這樣帶來的問題是,嚴重堵塞了後面代碼的執行,至於為什麼,主要是因為JS是單線程的。 問題 ...
  • 各位好啊,我又和大家見面了,也許你已經不記得大明湖畔的容嬤嬤,但是只要記得博客園中的我就好,希望我的博客能像一股清風,為你驅散炎熱的酷暑,好了,廢話不多說,開始上乾貨,我今天帶給大家的是前端工程化開發yeoman,bower ,grunt . 關於這三個工具在這裡就不過多介紹了,沒有用過的散仙們可以 ...
  • 在公司中使用nodejs構建代理伺服器實現前後臺分離,代碼不能拿出來,然後出現httpProxy代理資源的時候老是出現404.明明被代理的介面是存在的。代碼大概如下: 然後報錯或者是404錯誤碼。 解決方案: 在代理請求中,把請求頭中的host給刪除,改進代碼如下: 然後如期運行正確。 http:/ ...
  • 一些常見的狀態碼為: 200 - 伺服器成功返回網頁 404 - 請求的網頁不存在 503 - 服務不可用 所有狀態解釋: 1xx(臨時響應)表示臨時響應並需要請求者繼續執行操作的狀態代碼。代碼 說明 100 (繼續) 請求者應當繼續提出請求。 伺服器返回此代碼表示已收到請求的第一部分,正在等待其餘 ...
  • Range對象基本用法 效果圖如下(在谷歌瀏覽器下的展示) 代碼如下 在火狐瀏覽器下的展示 為什麼會出現這種情況呢,因為火狐瀏覽器下可以針對不連續的內容多選. Range對象之SelectNode和selectNodeContents方法 效果圖如下 代碼內容如下: selectNodeConten ...
  • 本篇介紹如何創建一個ExtJS應用程式。並通過創建目錄、導入文件、編寫代碼及分析代碼等步驟來解釋第一個ExtJS程式。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...