面试金典--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.mzph.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/√…