全局变量和局部变量的差别(从二分搜索简易理解)

关于全局变量和局部变量的区别

这个问题的思考源于一个很简单的算法实例——二分搜索。代码如下:

int binarySearch(int a[],int x, int n)

{

     int left = 0;

     int right = n - 1;

     int i = 0;

     while (left <= right)

     {

           int middle = left + (right - left) / 2;//防止溢出

           if (x == a[middle])

           {               return middle;};

           if (x > a[middle])

                left = middle + 1;

          else

                right = middle - 1;

          i++;

};

     return -1;

};

 

其中高亮字段中的middle作为局部变量在while循环结构体之内时,程序正常运行。但当该语句中的middle作为全局变量在while之前时,程序陷入了死循环。通过停点检查发现,当middle作为全局变量时,middle= left + (right - left) / 2不变且这里的left和right都是初始值。

       由此可以直观的看出全局变量和局部变量的区别,即当变量a的数值变化有赖于循环体时,应当把它作为局部变量。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值