面試金典--11.5

題目描述:給定排序后的字符串數組,中間有一些空串,要求找到給定字符串的位置

思路:

(1)遍歷,最慢的

(2)二分查找,當mid處為空串,就找到最近的非空串繼續尋找。如果需要找空串?(單獨處理)

  1 #include <iostream>
  2 #include <queue>
  3 #include <climits>
  4 #include <algorithm>
  5 #include <memory.h>
  6 #include <stdio.h>
  7 #include <ostream>
  8 #include <vector>
  9 #include <list>
 10 #include <cmath>
 11 #include <string>
 12 #include <stdexcept>
 13 #include <stack>
 14 #include <map>
 15 using namespace std;
 16 
 17 int fun(vector<string> a,string target)
 18 {
 19     int l = 0;
 20     int r = a.size() - 1;
 21     while(l <= r)
 22     {
 23         int mid = (l+r)/2;
 24         if(a[mid] == target)
 25         {
 26             return mid;
 27         }
 28         else if(a[mid] == "")
 29         {
 30             int k = mid + 1;
 31             while(k <= r)
 32             {
 33                 if(a[k] != "")
 34                     break;
 35             }
 36             if(k <= r)
 37             {
 38                 if(a[k] == target)
 39                 {
 40                     return k;
 41                 }
 42                 else if(a[k] > target)
 43                 {
 44                     r = k - 1;
 45                 }
 46                 else if(a[k] < target)
 47                 {
 48                     l = k + 1;
 49                 }
 50             }
 51             else
 52             {
 53                 k = mid - 1;
 54                 while(k >= l)
 55                 {
 56                     if(a[k] != "")
 57                         break;
 58                 }
 59                 if(k >= l)
 60                 {
 61                     if(a[k] == target)
 62                     {
 63                         return k;
 64                     }
 65                     else if(a[k] > target)
 66                     {
 67                         r = k - 1;
 68                     }
 69                     else if(a[k] < target)
 70                     {
 71                         l = k + 1;
 72                     }
 73                 }
 74                 else
 75                     return -1;
 76             }
 77         }
 78         else if(a[mid] > target)
 79         {
 80             r = mid - 1;
 81         }
 82         else if(a[mid] < target)
 83         {
 84             l = mid + 1;
 85         }
 86     }
 87 }
 88 
 89 int main()
 90 {
 91     vector<string> input;
 92     input.push_back("at");
 93     input.push_back("");
 94     input.push_back("");
 95     input.push_back("");
 96     input.push_back("ball");
 97     input.push_back("");
 98     input.push_back("");
 99     input.push_back("car");
100     input.push_back("");
101     input.push_back("");
102     input.push_back("dad");
103     input.push_back("");
104     input.push_back("");
105     cout<<fun(input,"ball")<<endl;
106     return 0;
107 }

?

轉載于:https://www.cnblogs.com/cane/p/3810769.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/258474.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/258474.shtml
英文地址,請注明出處:http://en.pswp.cn/news/258474.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

win10 平臺VS2019最簡安裝實現C++/C開發

這兩天一直在安裝vs2015,總是卡在visual studio 2015 出現安裝包丟失或損壞的現象&#xff0c;盡管按照網上很多方法嘗試解決&#xff0c;但是一直不行。算了。還是使用最新版的VS 2019安裝&#xff0c;沒想到很順利。 下面總結一下在win10平臺上最簡安裝VS2019&#xff0c;實…

Hook的兩個小插曲

看完了前面三篇文章后&#xff0c;這里我們來一個小插曲~~~~ 第一個小插曲。是前面文章一個CM精靈的分析。我們這里使用hook代碼來搞定。 第二個小插曲&#xff0c;是如今一些游戲&#xff0c;都有了支付上限&#xff0c;比如每天僅僅能花20塊錢來購買。好了。以下我們分開敘述…

### C++總結-[類成員函數]

C類中的常見函數。 #author: gr #date: 2015-07-23 #email: forgeruigmail.com 一、constructor, copy constructor, copy assignment, destructor 1. copy constructor必須傳引用&#xff0c;傳值編譯器會報錯 2. operator 返回值為引用&#xff0c;為了…

微信小程序和vue雙向綁定哪里不一樣_個人理解Vue和React區別

本文轉載自掘金&#xff0c;作者&#xff1a;binbinsilk&#xff0c;監聽數據變化的實現原理不同Vue 通過 getter/setter 以及一些函數的劫持&#xff0c;能精確知道數據變化&#xff0c;不需要特別的優化就能達到很好的性能React 默認是通過比較引用的方式進行的&#xff0c;如…

JS 省,市,區

1 // 純JS省市區三級聯動2 // 2011-11-30 by http://www.cnblogs.com/zjfree3 var addressInit function (_cmbProvince, _cmbCity, _cmbArea, defaultProvince, defaultCity, defaultArea) {4 var cmbProvince document.getElementById(_cmbProvince);5 var cmbCity…

使用極鏈/AutoDL云服務器復盤caffe安裝

繼上一次倒騰caffe安裝以后&#xff0c;因為博士畢業等原因&#xff0c;舊的服務器已經不能再使用&#xff0c;最近因論文等原因&#xff0c;不得不繼續來安裝一下我的caffe。這次運氣比較好&#xff0c;經歷了一晚上和一早上的痛苦之后&#xff0c;最終安裝成功了&#xff0c;…

ibatis中使用List作為傳入參數的使用方法及 CDATA使用

ibatis中list做回參很簡單&#xff0c;resultClass設為list中元素類型&#xff0c;dao層調用: (List)getSqlMapClientTemplate().queryForList("sqlName", paraName); 并經類型轉換即可&#xff0c;做入參還需要稍微調整下&#xff0c;本文主要講list做入參碰到的幾…

Samba服務

####################samba####################1.samba作用提供cifs協議實現共享文件2.安裝yum install samba samba-common samba-client -ysystemctl start smb nmbsystemctl enable smb nmb3.添加smb用戶smb用戶必須是本機用戶[rootlocalhost ~]# smbpasswd -a student New…

wpf 窗口的返回值_WPF Tips: Window.ShowDialog() 返回 true

Window.ShowDialog() 返回值為bool?。希望在窗口點擊OK時返回True。解決方法&#xff1a;ShowDialog()的注釋為&#xff1a;// Returns:// A System.Nullable value of type System.Boolean that specifies whether// the activity was accepted (true) or canceled (false). …

CodeForces 543D 樹形DP Road Improvement

題意&#xff1a; 有一顆樹&#xff0c;每條邊是好邊或者是壞邊&#xff0c;對于一個節點為x&#xff0c;如果任意一個點到x的路徑上的壞邊不超過1條&#xff0c;那么這樣的方案是合法的&#xff0c;求所有合法的方案數。 對于n個所有可能的x&#xff0c;輸出n個答案。 分析&am…

理解Javascritp中的引用

Author: bugall Wechat: bugallF Email: 769088641qq.com Github: https://github.com/bugall一&#xff1a; 函數中的引用傳遞 我們看下下面的代碼的正確輸出是什么 function changeStuff(a, b, c) {a a * 10;b.item "changed";c {item: "changed"}; …

通過擴展改善ASP.NET MVC的驗證機制[實現篇]

通過擴展改善ASP.NET MVC的驗證機制[實現篇] 原文:通過擴展改善ASP.NET MVC的驗證機制[實現篇]在《使用篇》中我們談到擴展的驗證編程方式&#xff0c;并且演示了本解決方案的三大特性&#xff1a;消息提供機制的分離、多語言的支持和多驗證規則的支持&#xff0c;我們現在來看…

canopen和1939區別_CAN 和 CANopen的區別和聯系

1、CAN與CANopen的共同點與不同點&#xff1a;CAN只定義了物理層與鏈路層&#xff0c;而沒有定義用戶層&#xff0c;用戶可根據自己的需要定義一些網絡上的通信約定&#xff1b; CANopen是在CAN的基礎上定義了用戶層&#xff0c;即規定了用戶、軟件、網絡終端等之間用來進行信…

ONOS系統架構演進,實現高可用性解決方案

上一篇文章《ONOS高可用性和可擴展性實現初探》講到了ONOS系統架構在高可用、可擴展方面技術概況&#xff0c;提到了系統在分布式集群中怎樣保證數據的一致性。在數據終于一致性方面&#xff0c;ONOS採用了Gossip協議。這一部分的變化不大&#xff0c;而在強一致性方案的選擇方…

Struts2_day01

Java Web開發常用框架 SSH(Struts2 Spring Hibernate)SSM(Struts2 Spring MyBatis)SSI(Struts2 Spring iBatis) 多種框架協同工作 Web層 -- Service層 -- Dao層 Struts2框架: Struts2是一個基于MVC設計模式的Web應用框架&#xff0c;它本質上相當于一個servlet&#xff0c;在MV…

使用 python 開發 Web Service

使用 python 開發 Web Service Python 是一種強大的面向對象腳本語言&#xff0c;用 python 開發應用程序往往十分快捷&#xff0c;非常適用于開發時間要求苛刻的原型產品。使用 python 開發 web service 同樣有語言本身的簡捷高速的特點&#xff0c;能使您快速地提供新的網絡服…

python中輸出n開始的5個奇數_送你99道Python經典練習題,練完直接上手做項目,免費送了來拿吧...

學python沒練習題怎么行、今天&#xff0c;給大家準備一個項目&#xff1a; 99道編程練習&#xff0c;這些題如果能堅持每天至少完成一道&#xff0c;一定可以幫大家輕松 get Python 的編程技能。目前&#xff0c;這個項目已經獲得了 2924 Stars&#xff0c;2468 Forks。首先&a…

java 基礎5

一、 什么是數組及其作用&#xff1f; 定義&#xff1a;具有相同數據類型的一個集合 作用&#xff1a;存儲連續的具有相同類型的數據 二、 java中如何聲明和定義數組 2.1 聲明和定義的語法&#xff1a; 數據類型[ ] 數組名&#xff1b;( int[ ] nums ; ) 或 數…

TFS(Team Foundation Server)介紹和入門

在本文的兩個部分中&#xff0c;我將介紹Team Foundation Server的一些核心特征&#xff0c;重點介紹在本產品的日常應用中是怎樣將這些特性結合在一起使用的。 作為一名軟件開發者&#xff0c;在我的職業生涯中&#xff0c;我常常會用到支持軟件開發過程的大量開發工具&#x…

逆函數求導公式_反函數求導法則

反函數的求導法則是&#xff1a;反函數的導數是原函數導數的倒數。例題&#xff1a;求yarcsinx的導函數。首先&#xff0c;函數yarcsinx的反函數為xsiny&#xff0c;所以&#xff1a;y‘1/sin’y1/cosy&#xff0c;因為xsiny&#xff0c;所以cosy√1-x2&#xff0c;所以y‘1/√…