首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C语言】神奇的“短路

C语言短路简介 C语言短路现象一般出现在逻辑运算符上,它有⼀个特点,就是总是先对左侧的表达式求值,再对右边的表达式求值,这个顺序是保证的。    ...这种情况称为“短路”。 逻辑与的“短路”     逻辑与操作符&&的规则是:只要有任何一边为假,那么结果就为假,只有两边同时为真,那么结果才为真,那么逻辑与怎么产生短路的呢?...逻辑或的“短路” 对于逻辑操作符||是怎么样的呢?...如果在前面判断时已经遇到假,那么就会短路,不再执行后面的语句,直接返回假。    ...此时来到后面一个表达式,前置++的b被初始化为了2,前置++的规则是先自增1,再使用,此时b就是3,而在C语言中,非零为真,此时逻辑与操作符遇到了真,就短路了,直接返回真,不会再判断后面的表达式,所以结果就是

7910

C语言中的短路现象

C语言一经出现,就以其功能丰富、表达能力强、灵活方便、应用面广等特点迅速在全世界普及和推广。C语言不但执行效率高,而且可移植性好,可以用来开发应用软件、驱动、操作系统等。...而C语言也是其它众多高级语言的鼻祖语言,所以说学习C语言是进入编程世界的必修课。 但是你知道吗,C语言也是会短路的!...短路现象1 比如有以下表达式: a && b && c 只有a为真(非0)才需要判断b的值;只有a和b都为真,才需要判断c的值。 举例 求最终a、b、c、d的值。...执行结果: 短路现象2 比如有以下表达式: a || b || c 只要a为真(非0)就不必判断b和c;只有a为假,才需要判断b的值;只有a和b都为假,才有必要判断c的值。...执行结果: 对于初学者来说,由于C语言灵活、强大,如果想要全面地掌握它,刚开始学起来可能会非常吃力。因此在学习C语言的过程中,要多看课本、代码,课本上没有的可以上网搜索。

2.7K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    再看最短路算法 1 —— 单源最短路

    学了多年的算法,最短路问题相当之常见———— 好久没写过最短路的问题了,直到昨天闲的无聊来了一题——BZOJ3402(HansBug:额才发现我弱到只能刷水的地步了TT) 一看这不是明显的单源最短路么呵呵...(估计还不止)和192ms究竟是怎样的差距啊QAQ,本人虽然早都听说过spfa的强大性,但是未曾想过差距会如此可怕,于是HansBug‘s Labo Online—— 准备:1.dijkstra单源最短路径模板...0:writeln(1,' ---> ',i,' : ','Unavailable'); 66 end; 67 readln; 68 end. 2.spfa单源最短路径模板...i]); 54 end; 55 readln; 56 end. 3.bat对拍小程序 (PS:由于Bellman-Ford算法具有超高的时空浪费量,还有...Floyd一般不用于单源最短路,所以只准备这些) 还有:这次采用的对拍模式如下——模拟一般OI赛制上的10组数据,30%数据满足规模为N<=10000 M<=100000;60%的数据满足规模为N<=30000

    2K60

    简单但容易掉坑,C语言所谓的短路现象

    C语言短路现象算是C语言的基础吧,不过有时候代码写得不规范也容易引入一些bug,所以这些操作在工程师实践中尽量少用。 虽然下面找的例子比较简单,但如果后面是其他表达式,或许你并不会那么容易分辨。...好了,下面的案例来源于网络,仅供参考: 短路现象1 比如有以下表达式: a && b && c 只有a为真(非0)才需要判断b的值;只有a和b都为真,才需要判断c的值。...d=%d\n",a,b,c,d); } 因为a++是先判断a的值再自加,而a初始值为0, 所以(a++)为假,由短路现象可知&&后面式子b++和--c就都不会执行;对于赋值语句,是先将a的值赋值给d,然后再自加...执行结果: 短路现象2 比如有以下表达式: a || b || c 只要a为真(非0)就不必判断b和c;只有a为假,才需要判断b的值;只有a和b都为假,才有必要判断c的值。...("a=%d b=%d c=%d d=%d\n",a,b,c,d); } 因为a++是先判断a的值再自加,而a初始值为0, 所以(a++)为假,由短路现象可知,还需要继续判断 || 后面的表达式b++,

    10210

    C语言逆向之表达式短路分析及应用

    大家在学习C语言过程中,可能会见到过一些这样的题,就是表达式短路,表达式短路主要体现在C语言中逻辑运算符&&和||。今天将对表达式短路的做逆向分析,来深入理解它。...首先利用表达式短路,我们可以写一个很经典的累加求和的函数,代码如下: ?...功能很简单,就是求1+2+…+99+100的数字和的一个程序,但用递归写了出来,利用逻辑与运算,左边判断是否递归到0,右边累加求和,其中的技巧巧妙的运用逻辑与运算的短路特点,实现累加的效果。...0040D718 cmp dword ptr [ebp+8],0 ;判断ZF标志位是否为1然后进行跳转,到return处 0040D71C je...0040D735 mov eax,dword ptr [ebp+8] 大家通过阅读汇编代码,上下文联系应该就可以分析出来,递归调用时候的每次参数递减,进行累加求和,正因为逻辑与运算的短路特点会先判断左边

    80351

    容易出错的C语言指针

    C语言指针说难不难但是说容易又是容易出错的地方,因此不管是你要做什么只要用到C指针你就跳不过,今天咱们就以   十九个例子来给大家简单的分析一下指针的应用,最后会有C语言视频资料提供给大家更加深入的参考...说明函数的返回值是一个整型数据   Int (*p)(int); //从P 处开始,先与指针结合,说明P 是一个指针,然后与()结合,说明指针指向的是一个函数,然后再与()里的int 结合,说明函数有一个int 型的参数,再与外层的.../可以先跳过,不看这个类型,过于复杂从P 开始,先与()结合,说明P 是一个函数,然后进入()里面,与int 结合,说明函数有一个整型变量参数,然后再与外面的*结合,说明函数返回的是一个指针,,然后到外面一层...所有的C/C++编译器在排列数组的单元时,总是把各个数组单元存放在连续的存储区里,单元和单元之间没有空隙。...*(s+3);*(s+3)=*(s+0);*(s+0)=c;   c=*(s+2);*(s+2)=*(s+1);*(s+1)=c;   }   注意这是一个32 位程序,故int 类型占了四个字节,char

    91520

    容易出错的C语言指针

    C语言指针说难不难但是说容易又是容易出错的地方,因此不管是你要做什么只要用到C指针你就跳不过,今天咱们就以   十九个例子来给大家简单的分析一下指针的应用,最后会有C语言视频资料提供给大家更加深入的参考...说明函数的返回值是一个整型数据   Int (*p)(int); //从P 处开始,先与指针结合,说明P 是一个指针,然后与()结合,说明指针指向的是一个函数,然后再与()里的int 结合,说明函数有一个int 型的参数,再与外层的.../可以先跳过,不看这个类型,过于复杂从P 开始,先与()结合,说明P 是一个函数,然后进入()里面,与int 结合,说明函数有一个整型变量参数,然后再与外面的*结合,说明函数返回的是一个指针,,然后到外面一层...所有的C/C++编译器在排列数组的单元时,总是把各个数组单元存放在连续的存储区里,单元和单元之间没有空隙。...*(s+3);*(s+3)=*(s+0);*(s+0)=c;   c=*(s+2);*(s+2)=*(s+1);*(s+1)=c;   }   注意这是一个32 位程序,故int 类型占了四个字节,char

    1.1K40

    算法|Dijkstra最短路算法

    01 — 单源最短路径 首先解释什么是单源最短路径,所谓单源最短路径就是指定一个出发顶点,计算从该源点出发到其他所有顶点的最短路径。...如下图所示,如果源点设为A,那么单源最短路径问题,就是求解从A到B,从A到C,从A到D,从A到E,从A到F的最短路径。 ?...比如,从A到D的最短路径,通过肉眼观察可以得出为如下,A->C->D,距离等于3+3=6,其中A->C边上的数值3称为权重,又知这是无向图,从C到A的权重也为3。 ?...02 — Dijkstra算法求单源最短路径 这个算法首先设置了两个集合,S集合和V集合。S集合初始只有源顶点即顶点A,V集合初始为除了源顶点以外的其他所有顶点,如下图所示: ?...Dijkstra算法会选择A->B,A->C的距离最小的,挑选C,放入S集合中,但是更新dist字典的时候,可以同时更新A->B和A->C的距离,示意图如下: ?

    6.3K50

    短路径-Dijkstra算法

    迪杰斯特拉算法(Dijkstra)是由荷兰计算机科学家狄克斯特拉于1959 年提出的,因此又叫狄克斯特拉算法。是从一个顶点到其余各顶点的最短路算法,解决的是有权图中最短路径问题。...-来自百度百科 一.最短路径问题的求解 1、单源最短路径用Dijkstra算法; 2、所有顶点间的最短路径用Floyd算法。...Dijikstra算法所求解的问题是:大概有这样一个有权图,Dijkstra算法可以计算任意节点到其他节点的最短路径。 ?...< 'A 到 B,C,E 的距离' ) 则更新U; 7.循环执行 4、5 两步骤,直至遍历结束,得到A 到其他节点的最短路径。...图解2 3.这时候 A->B, A->C 都为3,没关系。其实这时候他俩都是最短距离,如果从算法逻辑来讲的话,会先取到B点。

    7K31

    短路径-Dijkstra算法

    Dijkstra算法,又称"迪杰斯特拉算法",是从一个顶点到其余各顶点的最短路算法,解决的是有向图中最短路径问题。迪杰斯特拉算法主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止。...算法解析 1: 设置2个顶点集合S,T  S 存储已经找到的最短路径点的距离  T 存储未处理过的顶点 2: 先把起点A存储到T.准备处理 3: 获取到T的起点A,首先起点A到起点A的距离是0,直接存储到...S:A=>{length:0,route:A}, 4: 然后通过起点,获取起点周围的几个点和距离,例如B距离1,C距离5,D距离3,存储到T 5: 起点到周围的点都是当前的最短路径,直接存储到S:B=>...,route:ABC} (假想情况,为了方便理解更新最短路径),如果长度大于之前的,则不处理该点 8: 继续获取到E,C周围的点.存储到T 9: 如果已经获取到了终点(可以不需要终点,则之前遍历全部点)...,则不再获取终点周围的点 重复7,8步骤,直到T不存在数据 在这个过程中,可以保证起点到所有点都是最短路算法图解过程 例如 10x10 宫格图中: ?

    2.8K40
    领券