整合營銷服務(wù)商

          電腦端+手機(jī)端+微信端=數(shù)據(jù)同步管理

          免費(fèi)咨詢熱線:

          JavaScript 算法每日一題:匯總區(qū)間

          JavaScript 算法每日一題:匯總區(qū)間

          友們! 從2024年7月26日起,我們即將開啟一段全新的算法學(xué)習(xí)之旅!
          感謝你們的支持,你們的熱情是我前進(jìn)的動(dòng)力! 學(xué)習(xí)計(jì)劃如下,期待與你一起成長:
          每日一題:每天一個(gè)新挑戰(zhàn);
          循序漸進(jìn):從易到難,扎實(shí)掌握;
          系統(tǒng)分類:按數(shù)據(jù)結(jié)構(gòu)分類,有助于構(gòu)建知識(shí)框架;
          豐富題量:100 道精選題,覆蓋簡單/中等/困難難度。

          題目描述

          給定一個(gè) 無重復(fù)元素有序 整數(shù)數(shù)組 nums

          返回 恰好覆蓋數(shù)組中所有數(shù)字最小有序 區(qū)間范圍列表 。也就是說,nums 的每個(gè)元素都恰好被某個(gè)區(qū)間范圍所覆蓋,并且不存在屬于某個(gè)范圍但不屬于 nums 的數(shù)字 x

          列表中的每個(gè)區(qū)間范圍 [a,b] 應(yīng)該按如下格式輸出:

          • "a->b" ,如果 a !=b
          • "a" ,如果 a==b

          示例 1:

          輸入:nums=[0,1,2,4,5,7]
          輸出:["0->2","4->5","7"]
          解釋:區(qū)間范圍是:
          [0,2] --> "0->2"
          [4,5] --> "4->5"
          [7,7] --> "7"

          示例 2:

          輸入:nums=[0,2,3,4,6,8,9]
          輸出:["0","2->4","6","8->9"]
          解釋:區(qū)間范圍是:
          [0,0] --> "0"
          [2,4] --> "2->4"
          [6,6] --> "6"
          [8,9] --> "8->9"

          提示:

          • 0 <=nums.length <=20
          • -2^31 <=nums[i] <=2^31 - 1
          • nums 中的所有值都 互不相同
          • nums 按升序排列

          代碼卡片

          分析/求解

          給定一個(gè)無重復(fù)元素的有序整數(shù)數(shù)組 nums,要求返回覆蓋所有數(shù)字的最小有序區(qū)間范圍列表。區(qū)間范圍列表中的每個(gè)區(qū)間 [a,b] 需要按特定格式輸出,且這些區(qū)間需要準(zhǔn)確涵蓋 nums 中的所有數(shù)字。

          方法一:順序遍歷

          1. 初始化兩個(gè)變量 startend 來表示當(dāng)前區(qū)間的起點(diǎn)和終點(diǎn)。
          2. 遍歷數(shù)組 nums
          • 如果當(dāng)前數(shù)字和前一個(gè)數(shù)字不連續(xù),則將前一個(gè)區(qū)間 [start, end] 加入結(jié)果,并更新 startend
          • 如果當(dāng)前數(shù)字和前一個(gè)數(shù)字連續(xù),則更新 end
          1. 遍歷結(jié)束后,將最后一個(gè)區(qū)間加入結(jié)果。
          2. 根據(jù)區(qū)間的起點(diǎn)和終點(diǎn)來生成對(duì)應(yīng)的字符串格式。
          • 時(shí)間復(fù)雜度:O(n),其中 n 是數(shù)組 nums 的長度。我們需要遍歷數(shù)組一次來生成區(qū)間列表。
          • 空間復(fù)雜度:O(1),除了返回結(jié)果外,我們只使用了常數(shù)空間來存儲(chǔ) startend 和臨時(shí)變量。
          function summaryRanges(nums) {
              if (nums.length===0) return [];
          
              let ranges=[];
              let start=nums[0], end=nums[0];
          
              for (let i=1; i < nums.length; i++) {
                  if (nums[i]===end + 1) {
                      end=nums[i];
                  } else {
                      ranges.push(start===end ? `${start}` : `${start}->${end}`);
                      start=nums[i];
                      end=nums[i];
                  }
              }
          
              ranges.push(start===end ? `${start}` : `${start}->${end}`);
              return ranges;
          }
          

          方法二:簡化實(shí)現(xiàn)

          與方法一相同,但在遍歷過程中直接處理區(qū)間并加入結(jié)果,從而簡化代碼邏輯。

          function summaryRanges(nums) {
              let ranges=[];
              for (let i=0; i < nums.length; i++) {
                  let start=nums[i];
                  while (i + 1 < nums.length && nums[i + 1]===nums[i] + 1) {
                      i++;
                  }
                  if (start !==nums[i]) {
                      ranges.push(`${start}->${nums[i]}`);
                  } else {
                      ranges.push(`${start}`);
                  }
              }
              return ranges;
          }
          

          總結(jié)

          這道題目考察了對(duì)有序數(shù)組的遍歷和區(qū)間處理能力。通過設(shè)計(jì)區(qū)間范圍生成函數(shù),我們需要準(zhǔn)確識(shí)別連續(xù)數(shù)字并生成對(duì)應(yīng)的字符串格式。

          最后

          如果你有其他思路或方法,歡迎在評(píng)論區(qū)分享!祝你編碼愉快!

          家好,很高興又見面了,我是姜茶的編程筆記,我們一起學(xué)習(xí)前端相關(guān)領(lǐng)域技術(shù),共同進(jìn)步,也歡迎大家關(guān)注、點(diǎn)贊、收藏、轉(zhuǎn)發(fā),您的支持是我不斷創(chuàng)作的動(dòng)力

          鐵子們!從 2024/07/26 開始,我們進(jìn)入算法專題篇的學(xué)習(xí)啦 。學(xué)習(xí)計(jì)劃如下:

          1?? 每日一題;

          2?? 學(xué)習(xí)順序是由易到難;

          3?? 題目按照數(shù)據(jù)結(jié)構(gòu)進(jìn)行分類;

          4?? 每個(gè)類型的題目預(yù)計(jì)安排 100 道題(簡單/中等/困難各 33 道);

          題目描述

          給你一個(gè)閉區(qū)間 [lower, upper] 和一個(gè) 按從小到大排序 的整數(shù)數(shù)組 nums ,其中元素的范圍在閉區(qū)間 [lower, upper] 當(dāng)中。

          如果一個(gè)數(shù)字 x[lower, upper] 區(qū)間內(nèi),并且 x 不在 nums 中,則認(rèn)為 x 缺失

          返回 準(zhǔn)確涵蓋所有缺失數(shù)字最小排序 區(qū)間列表。也就是說,nums 的任何元素都不在任何區(qū)間內(nèi),并且每個(gè)缺失的數(shù)字都在其中一個(gè)區(qū)間內(nèi)。

          示例 1:

          輸入: nums=[0, 1, 3, 50, 75], lower=0 , upper=99
          輸出: [[2,2],[4,49],[51,74],[76,99]]

          示例 2:

          輸入: nums=[-1], lower=-1, upper=-1
          輸出: []
          解釋:沒有缺失的區(qū)間,因?yàn)闆]有缺失的數(shù)字。

          提示:

          • -10^9 <=lower <=upper <=10^9
          • 0 <=nums.length <=100
          • lower <=nums[i] <=upper
          • nums 中的所有值 互不相同

          代碼卡片

          分析/求解

          這道題要求我們找到一個(gè)有序數(shù)組 nums 和一個(gè)區(qū)間 [lower, upper] 之間所有缺失的數(shù)字,并返回這些缺失數(shù)字的最小排序區(qū)間列表。每個(gè)區(qū)間表示一段連續(xù)的缺失數(shù)字。

          方法一:線性掃描

          1. 遍歷數(shù)組
          • lower 開始,遍歷 nums 數(shù)組的每個(gè)元素,并檢查相鄰元素之間的缺失數(shù)字。
          • 如果當(dāng)前元素和前一個(gè)元素之間存在缺失數(shù)字,我們需要記錄這些缺失的區(qū)間。
          1. 處理邊界情況
          • 在遍歷之前,檢查 lowernums[0] 之間的缺失情況。
          • 在遍歷結(jié)束后,檢查 nums[-1]upper 之間的缺失情況。
          1. 生成缺失區(qū)間
          • 如果缺失的數(shù)字是單個(gè),則直接記錄 [start, start]
          • 如果是多個(gè)連續(xù)的缺失數(shù)字,則記錄 [start, end]


          • 時(shí)間復(fù)雜度:O(n),其中 nnums 的長度。我們只需遍歷 nums 數(shù)組一次。
          • 空間復(fù)雜度:O(1),除了結(jié)果列表外,使用的額外空間與輸入的大小無關(guān)。
          var findMissingRanges=function (nums, lower, upper) {
              let result=[];
              let prev=lower - 1;
          
              for (let i=0; i <=nums.length; i++) {
                  let curr=(i < nums.length) ? nums[i] : upper + 1;
          
                  if (curr - prev >=2) {
                      result.push(getRange(prev + 1, curr - 1));
                  }
          
                  prev=curr;
              }
          
              return result;
          }
          
          function getRange(start, end) {
              if (start===end) {
                  return [start, start];
              } else {
                  return [start, end];
              }
          }
          

          方法二:雙指針法

          1. 雙指針遍歷
          • 使用兩個(gè)指針來記錄當(dāng)前處理的區(qū)間的起始位置和結(jié)束位置。
          • 一個(gè)指針指向當(dāng)前數(shù)字,另一個(gè)指針檢查下一個(gè)缺失數(shù)字。
          1. 合并區(qū)間
          • 如果兩個(gè)指針之間存在缺失數(shù)字,就記錄下這一段缺失區(qū)間。
          1. 處理邊界情況
          • 在開始遍歷之前,處理 [lower, nums[0]] 之間的缺失;
          • 在結(jié)束遍歷之后,處理 nums[-1]upper 之間的缺失。


          • 時(shí)間復(fù)雜度:O(n),與方法一相同,遍歷一次數(shù)組。
          • 空間復(fù)雜度:O(1),只使用了常數(shù)額外空間。
          var findMissingRanges=function (nums, lower, upper) {
              let result=[];
              let start=lower;
          
              for (let i=0; i <=nums.length; i++) {
                  let end=(i < nums.length) ? nums[i] - 1 : upper;
          
                  if (start <=end) {
                      result.push([start, end]);
                  }
          
                  if (i < nums.length) {
                      start=nums[i] + 1;
                  }
              }
          
              return result;
          }
          

          總結(jié)

          通過這道題,我們學(xué)會(huì)了如何處理有序數(shù)組中的缺失區(qū)間,并生成相應(yīng)的區(qū)間列表。方法一使用簡單的遍歷方法,適合理解;方法二使用雙指針,簡化了處理過程。兩種方法都能有效解決問題,具體選擇取決于實(shí)際需求。我更更新雙指針解法 !

          最后

          如果有任何問題或建議,歡迎在評(píng)論區(qū)留言交流!祝你編程愉快!

          LOOKUP函數(shù)的使用方法(入門篇)

          VLOOKUP是一個(gè)查找函數(shù),給定一個(gè)查找的目標(biāo),它就能從指定的查找區(qū)域中查找返回想要查找到的值。它的基本語法為:

          VLOOKUP(查找目標(biāo),查找范圍,返回值的列數(shù),精確OR模糊查找)

          下面以一個(gè)實(shí)例來介紹一下這四個(gè)參數(shù)的使用

          例1:如下圖所示,要求根據(jù)表二中的姓名,查找姓名所對(duì)應(yīng)的年齡。

          公式:B13=VLOOKUP(A13,$B:$D,3,0)

          參數(shù)說明:

          1查找目標(biāo):就是你指定的查找的內(nèi)容或單元格引用。本例中表二A列的姓名就是查找目標(biāo)。我們要根據(jù)表二的“姓名”在表一中A列進(jìn)行查找。

          公式:B13=VLOOKUP(A13,$B:$D,3,0)

          2查找范圍(VLOOKUP(A13,$B:$D,3,0)):指定了查找目標(biāo),如果沒有說從哪里查找,EXCEL肯定會(huì)很為難。所以下一步我們就要指定從哪個(gè)范圍中進(jìn)行查找。VLOOKUP的這第二個(gè)參數(shù)可以從一個(gè)單元格區(qū)域中查找,也可以從一個(gè)常量數(shù)組或內(nèi)存數(shù)組中查找。本例中要從表一中進(jìn)行查找,那么范圍我們要怎么指定呢?這里也是極易出錯(cuò)的地方。大家一定要注意,給定的第二個(gè)參數(shù)查找范圍要符合以下條件才不會(huì)出錯(cuò):

          A查找目標(biāo)一定要在該區(qū)域的第一列。本例中查找表二的姓名,那么姓名所對(duì)應(yīng)的表一的姓名列,那么表一的姓名列(列)一定要是查找區(qū)域的第一列。象本例中,給定的區(qū)域要從第二列開始,即$B:$D,而不能是$A:$D。因?yàn)椴檎业摹靶彰辈辉?A:$D區(qū)域的第一列。

          B 該區(qū)域中一定要包含要返回值所在的列,本例中要返回的值是年齡。年齡列(表一的D列)一定要包括在這個(gè)范圍內(nèi),即:$B:$D,如果寫成$B:$C就是錯(cuò)的。

          3返回值的列數(shù)(B13=VLOOKUP(A13,$B:$D,3,0))。這是VLOOKUP第3個(gè)參數(shù)。它是一個(gè)整數(shù)值。它怎么得來的呢。它是“返回值”在第二個(gè)參數(shù)給定的區(qū)域中的列數(shù)。本例中我們要返回的是“年齡”,它是第二個(gè)參數(shù)查找范圍$B:$D的第3列。這里一定要注意,列數(shù)不是在工作表中的列數(shù)(不是第4列),而是在查找范圍區(qū)域的第幾列。如果本例中要是查找姓名所對(duì)應(yīng)的性別,第3個(gè)參數(shù)的值應(yīng)該設(shè)置為多少呢。答案是2。因?yàn)樾詣e在$B:$D的第2列中。

          4精確OR模糊查找(VLOOKUP(A13,$B:$D,3,0)),最后一個(gè)參數(shù)是決定函數(shù)精確和模糊查找的關(guān)鍵。精確即完全一樣,模糊即包含的意思。第4個(gè)參數(shù)如果指定值是0或FALSE就表示精確查找,而值為1 或TRUE時(shí)則表示模糊。這里蘭色提醒大家切記切記,在使用VLOOKUP時(shí)千萬不要把這個(gè)參數(shù)給漏掉了,如果缺少這個(gè)參數(shù)默為值為模糊查找,我們就無法精確查找到結(jié)果了。

          一、VLOOKUP多行查找時(shí)復(fù)制公式的問題

          VLOOKUP函數(shù)的第三個(gè)參數(shù)是查找返回值所在的列數(shù),如果我們需要查找返回多列時(shí),這個(gè)列數(shù)值需要一個(gè)個(gè)的更改,比如返回第2列的,參數(shù)設(shè)置為2,如果需要返回第3列的,就需要把值改為3。。。如果有十幾列會(huì)很麻煩的。那么能不能讓第3個(gè)參數(shù)自動(dòng)變呢?向后復(fù)制時(shí)自動(dòng)變?yōu)?,3,4,5。。。

          在EXCEL中有一個(gè)函數(shù)COLUMN,它可以返回指定單元格的列數(shù),比如

          =COLUMNS(A1) 返回值1

          =COLUMNS(B1) 返回值2

          而單元格引用復(fù)制時(shí)會(huì)自動(dòng)發(fā)生變化,即A1隨公式向右復(fù)制時(shí)會(huì)變成B1,C1,D1。。這樣我們用COLUMN函數(shù)就可以轉(zhuǎn)換成數(shù)字1,2,3,4。。。

          例:下例中需要同時(shí)查找性別,年齡,身高,體重。

          公式:=VLOOKUP($A13,$B:$F,COLUMN(B1),0)

          公式說明:這里就是使用COLUMN(B1)轉(zhuǎn)化成可以自動(dòng)遞增的數(shù)字。

          二、VLOOKUP查找出現(xiàn)錯(cuò)誤值的問題。

          1、如何避免出現(xiàn)錯(cuò)誤值。

          EXCEL2003 在VLOOKUP查找不到,就#N/A的錯(cuò)誤值,我們可以利用錯(cuò)誤處理函數(shù)把錯(cuò)誤值轉(zhuǎn)換成0或空值。

          即:=IF(ISERROR(VLOOKUP(參數(shù)略)),"",VLOOKUP(參數(shù)略)

          EXCEL2007,EXCEL2010中提供了一個(gè)新函數(shù)IFERROR,處理起來比EXCEL2003簡單多了。

          IFERROR(VLOOKUP(),"")

          2、VLOOKUP函數(shù)查找時(shí)出現(xiàn)錯(cuò)誤值的幾個(gè)原因

          A、實(shí)在是沒有所要查找到的值

          B、查找的字符串或被查找的字符中含有空格或看不見的空字符,驗(yàn)證方法是用=號(hào)對(duì)比一下,如果結(jié)果是FALSE,就表示兩個(gè)單元格看上去相同,其實(shí)結(jié)果不同。

          C、參數(shù)設(shè)置錯(cuò)誤。VLOOKUP的最后一個(gè)參數(shù)沒有設(shè)置成1或者是沒有設(shè)置掉。第二個(gè)參數(shù)數(shù)據(jù)源區(qū)域,查找的值不是區(qū)域的第一列,或者需要反回的字段不在區(qū)域里,參數(shù)設(shè)置在入門講里已注明,請(qǐng)參閱。

          D、數(shù)值格式不同,如果查找值是文本,被查找的是數(shù)字類型,就會(huì)查找不到。解決方法是把查找的轉(zhuǎn)換成文本或數(shù)值,轉(zhuǎn)換方法如下:

          文本轉(zhuǎn)換成數(shù)值:*1或--或/1

          數(shù)值轉(zhuǎn)抱成文本:&""

          VLOOKUP函數(shù)的使用方法(進(jìn)階篇)

          一、字符的模糊查找

          在A列我們知道如何查找型號(hào)為“AAA”的產(chǎn)品所對(duì)應(yīng)的B列價(jià)格,即:

          =VLOOKUP(C1,A:B,2,0)

          如果我們需要查找包含“AAA”的產(chǎn)品名稱怎么表示呢?如下圖表中所示。

          公式=VLOOKUP("*"&A10&"*",A2:B6,2,0)

          公式說明:VLOOKUP的第一個(gè)參數(shù)允許使用通配符“*”來表示包含的意思,把*放在字符的兩邊,即"*" & 字符 & "*"。

          二、數(shù)字的區(qū)間查找

          數(shù)字的區(qū)間查找即給定多個(gè)區(qū)間,指定一個(gè)數(shù)就可以查找出它在哪個(gè)區(qū)間并返回這個(gè)區(qū)間所對(duì)應(yīng)的值。

          在VLOOKUP入門中我們提示VLOOKUP的第4個(gè)參數(shù),如果為0或FALSE是精確查找,如果是1或TRUE或省略則為模糊查找,那么實(shí)現(xiàn)區(qū)間查找正是第4個(gè)參數(shù)的模糊查找應(yīng)用。

          首先我們需要了解一下VLOOKUP函數(shù)模糊查找的兩個(gè)重要規(guī)則:

          1、引用的數(shù)字區(qū)域一定要從小到大排序。雜亂的數(shù)字是無法準(zhǔn)確查找到的。如下面A列符合模糊查找的前題,B列則不符合。

          2、模糊查找的原理是:給一定個(gè)數(shù),它會(huì)找到和它最接近,但比它小的那個(gè)數(shù)。詳見下圖說明。

          最后看一個(gè)實(shí)例:

          【例】:如下圖所示,要求根據(jù)上面的提成比率表,在提成表計(jì)算表中計(jì)算每個(gè)銷售額的提成比率和提成額。

          公式:=VLOOKUP(A11,$A:$B,2)

          公式說明:

          1、上述公式省略了VLOOKUP最后一個(gè)參數(shù),相當(dāng)于把第四個(gè)參數(shù)設(shè)置成1或TRUE。這表示VLOOKUP要進(jìn)行數(shù)字的區(qū)間查找。

          2、圖中公式中在查找5000時(shí)返回比率表0所對(duì)應(yīng)的比率1%,原因是0和10000與5000最接近,但VLOOKUP只選比查找值小的那一個(gè),所以公式會(huì)返回0所對(duì)應(yīng)的比率1%。

          VLOOKUP函數(shù)的使用方法(高級(jí)篇)

          一、VLOOKUP的反向查找。

          一般情況下,VLOOKUP函數(shù)只能從左向右查找。但如果需要從右向右查找,則需要把區(qū)域進(jìn)行“乾坤大挪移”,把列的位置用數(shù)組互換一下。

          例1:要求在如下圖所示表中的姓名反查工號(hào)。

          公式:=VLOOKUP(A9,IF({1,0},B2:B5,A2:A5),2,0)

          公式剖析:

          1、這里其實(shí)不是VLOOKUP可以實(shí)現(xiàn)從右至右的查找,而是利用IF函數(shù)的數(shù)組效應(yīng)把兩列換位重新組合后,再按正常的從左至右查找。

          2、IF({1,0},B2:B5,A2:A5)這是本公式中最重要的組成部分。在EXCEL函數(shù)中使用數(shù)組時(shí)(前提時(shí)該函數(shù)的參數(shù)支持?jǐn)?shù)組),返回的結(jié)果也會(huì)是一個(gè)數(shù)組。這里1和0不是實(shí)際意義上的數(shù)字,而是1相關(guān)于TRUE,0相當(dāng)于FALSE,當(dāng)為1時(shí),它會(huì)返回IF的第二個(gè)參數(shù)(B列),為0時(shí)返回第二個(gè)參數(shù)(A列)。根據(jù)數(shù)組運(yùn)算返回?cái)?shù)組,所以使用IF后的結(jié)果返回一個(gè)數(shù)組(非單元格區(qū)域):{"張一","A001";"趙三","A002";"楊五","A003";"孫二","A004"}

          二、VLOOKUP函數(shù)的多條件查找。

          VLOOKUP函數(shù)需要借用數(shù)組才能實(shí)現(xiàn)多條件查找。

          例2:要求根據(jù)部門和姓名查找C列的加班時(shí)間。

          分析:我們可以延用例1的思路,我們的努力方向不是讓VLOOKUP本身實(shí)現(xiàn)多條件查找,而是想辦法重構(gòu)一個(gè)數(shù)組。多個(gè)條件我們可以用&連接在一起,同樣兩列我們也可以連接成一列數(shù)據(jù),然后用IF函數(shù)進(jìn)行組合。

          公式:{=VLOOKUP(A9&B9,IF({1,0},A2:A5&B2:B5,C2:C5),2,0)}

          公式剖析:

          1、A9&B9 把兩個(gè)條件連接在一起。把他們做為一個(gè)整體進(jìn)行查找。

          2、A2:A5&B2:B5,和條件連接相對(duì)應(yīng),把部分和姓名列也連接在一起,作為一個(gè)待查找的整體。

          3、IF({1,0},A2:A5&B2:B5,C2:C5) 用IF({1,0}把連接后的兩列與C列數(shù)據(jù)合并成一個(gè)兩列的內(nèi)存數(shù)組。按F9后可以查看的結(jié)果為:

          {"銷售張一",1;"銷售趙三",5;"人事楊五",3;"銷售趙三",6}

          4、完成了數(shù)組的重構(gòu)后,接下來就是VLOOKUP的基本查找功能了,另外公式中含有多個(gè)數(shù)據(jù)與多個(gè)數(shù)據(jù)運(yùn)算(A2:A5&B2:B5),,所以必須以數(shù)組形式輸入,即按ctrl+shift后按ENTER結(jié)束輸入。

          三、VLOOKUP函數(shù)的批量查找。

          VLOOKUP一般情況下只能查找一個(gè),那么多項(xiàng)該怎么查找呢?

          例3 要求把如圖表中所有張一的消費(fèi)金額全列出來

          分析:經(jīng)過前面的學(xué)習(xí),我們也有這樣一個(gè)思路,我們?cè)趯?shí)現(xiàn)復(fù)雜的查找時(shí),努力的方向是怎么重構(gòu)一個(gè)查找內(nèi)容和查找的區(qū)域。要想實(shí)現(xiàn)多項(xiàng)查找,我們可以對(duì)查找的內(nèi)容進(jìn)行編號(hào),第一個(gè)出現(xiàn)的是后面連接1,第二個(gè)出現(xiàn)的連接2。。。

          公式:{=VLOOKUP(B&ROW(A1),IF({1,0},$B:$B&COUNTIF(INDIRECT("b2:b"&ROW(:)),B),$C:$C),2,)}

          公式剖析:

          1、B&ROW(A1) 連接序號(hào),公式向下復(fù)制時(shí)會(huì)變成B連接1,2,3

          2、給所有的張一進(jìn)行編號(hào)。要想生成編號(hào),就需要生成一個(gè)不斷擴(kuò)充的區(qū)域(INDIRECT("b2:b"&ROW(:)),然后在這個(gè)逐行擴(kuò)充的區(qū)域內(nèi)統(tǒng)計(jì)“張一”的個(gè)數(shù),在連接上$B:$B后就可以對(duì)所有的張一進(jìn)行編號(hào)了。

          3、IF({1,0}把編號(hào)后的B列和C組重構(gòu)成一個(gè)兩列數(shù)組

          通過以上的講解,我們需要知道,VLOOKUP函數(shù)的基本用法是固定的,要實(shí)現(xiàn)高級(jí)查找,就需要借助其他函數(shù)來重構(gòu)查找內(nèi)容和查找數(shù)組。

          VLOOKUP函數(shù)的使用方法(最高級(jí)篇)

          【例】工資表模板中,每個(gè)部門一個(gè)表。

          在查詢表中,要求根據(jù)提供的姓名,從銷售~綜合5個(gè)工作表中查詢?cè)搯T工的基本工資。

          分析:

          如果,我們知道A1是銷售部的,那么公式可以寫為:

          =VLOOKUP(A2,銷售!A:G,7,0)

          如果,我們知道A1可能在銷售或財(cái)務(wù)表這2個(gè)表中,公式可以寫為:

          =IFERROR(VLOOKUP(A2,銷售!A:G,7,0),VLOOKUP(A2,財(cái)務(wù)!A:G,7,0))

          意思是,如果在銷售表中查找不到(用iferror函數(shù)判斷),則去財(cái)務(wù)表中再查找。

          如果,我們知道A1可能在銷售、財(cái)務(wù)或服務(wù)表中,公式可以再次改為:

          =IFERROR(VLOOKUP(A2,銷售!A:G,7,0),IFERROR(VLOOKUP(A2,財(cái)務(wù)!A:G,7,0),VLOOKUP(A2,!A:G,7,0)))

          意思是從銷售表開始查詢,前面的查詢不到就到后面的表中查找。

          如果,有更多的表,如本例中5個(gè)表,那就一層層的套用下去。這也是我們今天提供的VLOOKUP多表查找

          方法1:

          =IFERROR(VLOOKUP(A2,服務(wù)!A:G,7,0),IFERROR(VLOOKUP(A2,人事!A:G,7,0),IFERROR(VLOOKUP(A2,綜合!A:G,7,0),IFERROR(VLOOKUP(A2,財(cái)務(wù)!A:G,7,0),IFERROR(VLOOKUP(A2,銷售!A:G,7,0),"無此人信息")))))

          方法2:

          =VLOOKUP(A2,INDIRECT(LOOKUP(1,0/COUNTIF(INDIRECT({"銷售";"服務(wù)";"人事";"綜合";"財(cái)務(wù)"}&"!a:a"),A2),{"銷售";"服務(wù)";"人事";"綜合";"財(cái)務(wù)"})&"!a:g"),7,0)

          你只需要修改以下部分,就可以直接套用

          A2:查找的內(nèi)容

          {""}:大括號(hào)內(nèi)是要查找的多個(gè)工作表名稱,用逗號(hào)分隔

          a:a:本例是姓名在各個(gè)表中的A列,如果在B列則為b:b

          a:g:vlookup查找的區(qū)域

          7:是vlookup第3個(gè)參數(shù),相對(duì)應(yīng)的列數(shù)。你懂的。

          公式思路說明:

          1、確定員工是在哪個(gè)表中。這里利用countif函數(shù)可以多表統(tǒng)計(jì)來分雖計(jì)算各個(gè)表中該員工存在的個(gè)數(shù)。

          2、利用lookup(1,0/(數(shù)組),數(shù)組)結(jié)構(gòu)取得工作表的名稱

          3、利用indirec函數(shù)把字符串轉(zhuǎn)換成單元格引用。

          4、利用vlookup查找。

          示例表格下載:(粘貼到電腦瀏覽器地址欄中按回車下載)

          http://www.excelpx.com/home/upload/2015_04/temp_15041319138821.zip

          vlookup函數(shù)的跨表查找,新手同學(xué)建議用iferror+vlookup的模式,公式雖然長,但容易理解且公式不容易出錯(cuò)。如果你有一定基礎(chǔ),倒可以試試第2種方法。

          VLOOKUP函數(shù)的使用方法(12種常見錯(cuò)誤)

          一、函數(shù)參數(shù)使用錯(cuò)誤。

          第1種:第2個(gè)參數(shù)區(qū)域設(shè)置錯(cuò)誤之1。

          例:如下圖所示,根據(jù)姓名查找齡時(shí)產(chǎn)生錯(cuò)誤。

          錯(cuò)誤原因: vlookup函數(shù)第二個(gè)參數(shù)是查找區(qū)域,該區(qū)域的第1列有一個(gè)必備條件,就是查找的對(duì)象(A9),必須對(duì)應(yīng)于區(qū)域的第1列。本例中是根據(jù)姓名查找的,那么,第二個(gè)參數(shù)姓名必須是在區(qū)域的第1列位置,而上述公式中姓名列是在區(qū)域A1:E6的第2列。所以公式應(yīng)改為:

          =VLOOKUP(A9,B1:E6,3,0)

          第2種:第2個(gè)參數(shù)區(qū)域設(shè)置錯(cuò)誤之2。

          例2 如下圖所示根據(jù)姓名查找職務(wù)時(shí)產(chǎn)生查找錯(cuò)誤。

          錯(cuò)誤原因:本例是根據(jù)姓名查找職務(wù),可大家注意一下,第2個(gè)參數(shù)B1:D6根本就沒有包括E列的職務(wù),當(dāng)然會(huì)產(chǎn)生錯(cuò)誤了。所以公式應(yīng)改為:

          =VLOOKUP(A9,B1:E6,4,0)

          第3種:第4個(gè)參數(shù)少了或設(shè)置錯(cuò)誤。

          例3,如下圖所示根據(jù)工號(hào)查找姓名

          錯(cuò)誤原因:vlookup第四個(gè)參數(shù)為0時(shí)表示精確查找,為1或省略時(shí)表示模糊查找。如果忘了設(shè)置第4個(gè)參數(shù)則會(huì)被公式誤以為是故意省略,按模糊查找進(jìn)行。當(dāng)區(qū)域也不符合模糊查找規(guī)則時(shí),公式就會(huì)返回錯(cuò)誤值。所以公式應(yīng)改為。

          =VLOOKUP(A9,A1:D6,2,0)

          或=VLOOKUP(A9,A1:D6,2,) 注:當(dāng)參數(shù)為0時(shí)可以省略,但必須保留“,”號(hào)。

          二、數(shù)字格式不同,造成查找錯(cuò)誤。

          第4種查找為數(shù)字,被查找區(qū)域?yàn)槲谋拘蛿?shù)字。

          例4:如下圖所示根據(jù)工號(hào)查找姓名,查找出現(xiàn)錯(cuò)誤。

          錯(cuò)誤原因:在vlookup函數(shù)查找過程中,文本型數(shù)字和數(shù)值型數(shù)字會(huì)被認(rèn)為不同的字符。所以造成無法成功查找。

          解決方案:把查找的數(shù)字在公式中轉(zhuǎn)換成文本型,然后再查找。即:

          =VLOOKUP(A9&"",A1:D6,2,0)

          第5種查找格式為文本型數(shù)字,被查找區(qū)域?yàn)閿?shù)值型數(shù)字。

          例5:如下圖所示根據(jù)工號(hào)查找姓名,查找出現(xiàn)錯(cuò)誤

          錯(cuò)誤原因:同4

          解決方法:把文本型數(shù)字轉(zhuǎn)換成數(shù)值型。即:

          =VLOOKUP(A9*1,A1:D6,2,0)

          三、引用方式使公式復(fù)制后產(chǎn)生錯(cuò)誤。

          第6種沒有正確的使用引用方式,造成在復(fù)制公式后區(qū)域發(fā)生變動(dòng)引起錯(cuò)誤。

          例6,如下圖所示,當(dāng)C9的公式復(fù)制到C10和C11后,C10公式返回錯(cuò)誤值。

          錯(cuò)誤原因:由于第二個(gè)參數(shù)A2:D6是相對(duì)引用,所以向下復(fù)制公式后會(huì)自動(dòng)更改為A3:D7,而A10中的工號(hào)A01所在的行,不在A3:D7區(qū)域中,從而造成查找失敗。

          解決方案:把第二個(gè)參數(shù)的引用方式由相對(duì)引用改為絕對(duì)引用即可。

          B9公式改為:=VLOOKUP(A9,$A:$D,2,0)

          四、多余的空格或不可見字符

          第7種數(shù)據(jù)表中含有多余的空格。

          例7 如下圖所示,由于A列工號(hào)含有多余的空格,造成查找錯(cuò)誤。

          錯(cuò)誤原因:多一個(gè)空格,用不帶空格的字符查找當(dāng)然會(huì)出錯(cuò)了。

          解決方案: 1 手工替換掉空格。建議用這個(gè)方法

          2 在公式中用trim函數(shù)替換空格而必須要用數(shù)據(jù)公式形式輸入。

          即:=VLOOKUP(A9,TRIM(A1:D6),2,0) 按ctrl+shift+enter輸入后數(shù)組形式為 {=VLOOKUP(A9,TRIM(A1:D6),2,0)}

          第8種:類空格但非空格的字符。

          在表格存在大量的“空格”,但又用空格無法替換掉時(shí),這些就是類空格的不可見字符,這時(shí)可以“以其人之道還之其人之身”,直接在單元格中復(fù)制不可見字符粘貼到替換窗口,替換掉即可。

          第9種:不可見字符的影響

          例: 如下圖所示的A列中,A列看不去不存在空格和類空格字符,但查找結(jié)果還是出錯(cuò)。

          出錯(cuò)原因:這是從網(wǎng)頁或數(shù)據(jù)庫中導(dǎo)入數(shù)據(jù)時(shí)帶來的不可見字符,造成了查找的錯(cuò)誤。

          解決方案:在A列后插入幾列空列,然后對(duì)A列進(jìn)行分列操作(數(shù)據(jù) - 分列),即可把不可見字符分離出去。

          在日常vlookup函數(shù)查找錯(cuò)誤示例中,第8種是最常見的一種錯(cuò)誤之一。同學(xué)遇到vlookup查找錯(cuò)誤時(shí),如果參數(shù)設(shè)置沒有問題,就看一下數(shù)據(jù)表中有沒有多余的空格。

          第10種:反向查找vlookup不支持產(chǎn)生的錯(cuò)誤。

          例10 如下圖所示的表中,根據(jù)姓名查找工號(hào),結(jié)果返回了錯(cuò)誤。

          錯(cuò)誤原因:vlookup不支持反向查找。

          解決方法:1 用if函數(shù)重組區(qū)域,讓兩列顛倒位置。

          =VLOOKUP(D8,IF({0,1},D2:D4,E2:E4),2,0)

          2 用index+match組合實(shí)現(xiàn)。

          =INDEX(D2:D4,MATCH(D8,E2:E4,0))

          第11種:通配符引起的查找錯(cuò)誤

          例11,如下圖所示,根據(jù)區(qū)間查找提成返回錯(cuò)誤值。

          錯(cuò)誤原因:~用于查找通配符,如果在vlookup公式中出現(xiàn),會(huì)被認(rèn)為特定用途,非真正的~。如在表格中查找3*6 ,356,376也被查找到。

          如果精確查找3*6,需要使用~,如下圖所示。

          解決方法:用~~就可以表示查找~了。所以公式可以修改為

          =VLOOKUP(SUBSTITUTE(A8,"~","~~"),A2:B4,2,0)

          第12種:vlookup函數(shù)第1個(gè)參數(shù)不直接支持?jǐn)?shù)組形式產(chǎn)生的錯(cuò)誤

          例12:如下圖所示,同時(shí)查找A和C產(chǎn)品的和,然后用SUM求和。

          錯(cuò)誤原因: VLOOKUP第一個(gè)參數(shù)不能直接用于數(shù)組。

          解決方法:利用N/T+IF結(jié)構(gòu)轉(zhuǎn)化一下數(shù)組,如果不了解N/T+IF結(jié)構(gòu)用法,可以參考http://www.excelpx.com/thread-174362-1-1.html。公式修改為:

          =SUM(VLOOKUP(T(IF({1},A8:B8)),A2:B5,2,))

          vlookup函數(shù)常見的12種錯(cuò)誤我們介紹完了,掌握了這些技巧可能在以后的工作中不再會(huì)被vlookup公式困繞了

          End.

          作者:伊麗莎白麗

          來源:簡書


          主站蜘蛛池模板: 中文字幕一区二区人妻| 国产精品一区二区av| 亚洲AV永久无码精品一区二区国产| 99国产精品欧美一区二区三区| www.亚洲一区| 亚洲国产欧美一区二区三区| 久久福利一区二区| 精品久久国产一区二区三区香蕉| 国产乱码精品一区二区三区| 久久91精品国产一区二区| 亚洲日本一区二区一本一道 | 中文字幕在线播放一区| 韩国福利视频一区二区| 欧美一区内射最近更新| 国产精品制服丝袜一区| 久久精品国产AV一区二区三区| 无码精品黑人一区二区三区| 夜夜嗨AV一区二区三区| 91久久精一区二区三区大全| 成人免费一区二区三区| 国产成人高清精品一区二区三区 | 乱色精品无码一区二区国产盗| 亚洲乱码国产一区三区| 少妇无码AV无码一区| 亚洲无线码在线一区观看| 国产探花在线精品一区二区| 亚洲乱色熟女一区二区三区丝袜| 色婷婷AV一区二区三区浪潮| 久久精品国产免费一区| 亚洲国产一区二区三区青草影视| 亚洲国产精品第一区二区| 人妻夜夜爽天天爽爽一区| 亚洲AV成人一区二区三区在线看 | 午夜福利一区二区三区在线观看 | 在线播放国产一区二区三区 | 久久se精品一区精品二区国产 | 手机福利视频一区二区| 国产精品亚洲综合一区在线观看 | 久久久精品人妻一区二区三区蜜桃| 亚洲国产精品乱码一区二区 | 国产一区二区三区不卡AV|