博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
位运算符 优先级 折半搜索
阅读量:6422 次
发布时间:2019-06-23

本文共 1939 字,大约阅读时间需要 6 分钟。

看编程珠玑,深知二分搜索的用处之大,自己写了一遍,竟然出了死循环。代码如下:

1 int bsearch(int *data, int val,int left, int right) 2 { 3     if(left <= right) 4     { 5         int mid = left + (right-left)>>1; 6         if(data[mid]==val) 7             return mid; 8         else if(data[mid]

感觉没有特殊的地方,经过调试发现,第5行,当left = 5 ,right = 9时,mid = 5 + (9-5)>>1;结果是4 !!!!为何不是7? 运算符优先级,+号 高于 位运算符。 相当于 (5 + (9-5))>>1 ,刚好数组内data[4] < val ,造成死循环。。。

 

附1、折半搜索的递归和非递归实现:

1 #include 
2 #include
3 4 using namespace std; 5 6 //递归实现 7 int bsearch(int *data, int val,int left, int right) 8 { 9 if(left <= right)10 {11 int mid = left + ((right-left)>>1);12 if(data[mid]==val)13 return mid;14 else if(data[mid]
>1);28 if(data[mid]==val)29 return mid;30 else if(data[mid]

 

附2、运算符优先级:

优先级

运算符

名称或含义

使用形式

结合方向

说明

1

[]

数组下标

数组名[常量表达式]

左到右

 

()

圆括号

(表达式)/函数名(形参表)

 

.

成员选择(对象)

对象.成员名

 

->

成员选择(指针)

对象指针->成员名

 

2

-

负号运算符

-表达式

右到左

单目运算符

(类型)

强制类型转换

(数据类型)表达式

 

++

自增运算符

++变量名/变量名++

单目运算符

--

自减运算符

--变量名/变量名--

单目运算符

*

取值运算符

*指针变量

单目运算符

&

取地址运算符

&变量名

单目运算符

!

逻辑非运算符

!表达式

单目运算符

~

按位取反运算符

~表达式

单目运算符

sizeof

长度运算符

sizeof(表达式)

 

3

/

表达式/表达式

左到右

双目运算符

*

表达式*表达式

双目运算符

%

余数(取模)

整型表达式/整型表达式

双目运算符

4

+

表达式+表达式

左到右

双目运算符

-

表达式-表达式

双目运算符

5

<<

左移

变量<<表达式

左到右

双目运算符

>>

右移

变量>>表达式

双目运算符

6

>

大于

表达式>表达式

左到右

双目运算符

>=

大于等于

表达式>=表达式

双目运算符

<

小于

表达式<表达式

双目运算符

<=

小于等于

表达式<=表达式

双目运算符

7

==

等于

表达式==表达式

左到右

双目运算符

!=

不等于

表达式!= 表达式

双目运算符

8

&

按位与

表达式&表达式

左到右

双目运算符

9

^

按位异或

表达式^表达式

左到右

双目运算符

10

|

按位或

表达式|表达式

左到右

双目运算符

11

&&

逻辑与

表达式&&表达式

左到右

双目运算符

12

||

逻辑或

表达式||表达式

左到右

双目运算符

13

?:

条件运算符

表达式1? 表达式2: 表达式3

右到左

三目运算符

14

=

赋值运算符

变量=表达式

右到左

 

/=

除后赋值

变量/=表达式

 

*=

乘后赋值

变量*=表达式

 

%=

取模后赋值

变量%=表达式

 

+=

加后赋值

变量+=表达式

 

-=

减后赋值

变量-=表达式

 

<<=

左移后赋值

变量<<=表达式

 

>>=

右移后赋值

变量>>=表达式

 

&=

按位与后赋值

变量&=表达式

 

^=

按位异或后赋值

变量^=表达式

 

|=

按位或后赋值

变量|=表达式

 

15

,

逗号运算符

表达式,表达式,…

左到右

从左向右顺序运算

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

上表参考:  http://www.slyar.com/blog/c-operator-priority.html

 

 

 

 

 

 

 

 

转载地址:http://pnrra.baihongyu.com/

你可能感兴趣的文章
自己设计的SSO登录流程图
查看>>
[oracle] ORA-12514 TNS 监听程序当前无法识别连接描述符中请求服务 的解决方法
查看>>
【SpringMVC】SpringMVC系列3之@PathVariable映射URL占位符参数
查看>>
订单、支付、退款、发货、退货等编号自动生成类
查看>>
MFC之菜单
查看>>
htop 源码安装
查看>>
Hadoop 2.6 MapReduce运行原理详解
查看>>
How to run Tomcat without root privileges? 常规用户使用tomcat的80端口
查看>>
P6 EPPM R16.1安装与配置指南(三)
查看>>
RHEL7挂载ISO做本地yum
查看>>
[kafka] 005_kafka_Java_API
查看>>
MySQL for Excel用法
查看>>
mysql怎样建表及mysql优化
查看>>
__VA_ARGS__用法(转)
查看>>
Greenplum 生成加分区语句
查看>>
转:虚拟方法跳过父类继承调用祖父类的代码 --值得试一试
查看>>
remove-duplicates-from-sorted-array
查看>>
redis其他问题
查看>>
DS实验题 击鼓传花
查看>>
Java多线程系列--“JUC锁”03之 公平锁(一)
查看>>