程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> C說話邏輯運算符常識整頓

C說話邏輯運算符常識整頓

編輯:關於C++

C說話邏輯運算符常識整頓。本站提示廣大學習愛好者:(C說話邏輯運算符常識整頓)文章只能為提供參考,不一定能成為您想要的結果。以下是C說話邏輯運算符常識整頓正文


在高中數學中,我們學過邏輯運算,例如p為真命題,q就假命題,那末“p且q”為假,“p或q”為真,“非q”為真。

在C說話中,也有相似的邏輯運算:

運算符 解釋 聯合性 舉例 && 與運算,雙目,對應數學中的“且” 左聯合 1&&0、(9>3)&&(b>a) || 或運算,雙目 左聯合 1||0、(9>3)||(b>a) ! 非運算。單目 右聯合 !a、!(2<5)

 邏輯運算的成果

在編程中,我們普通將零值稱為“假”,將非零值稱為“真”。邏輯運算的成果也只要“真”和“假”,“真”對應的值為 1,“假”對應的值為 0。

1) 與運算(&&)

介入運算的兩個量都為真時,成果才為真,不然為假。例如:

5&&0

5為真,0為假,相與的成果為假,也就是 0。

(5>0) && (4>2)

5>0 的成果是1,為真,4>2成果是1,也為真,所以相與的成果為真,也就是1。

2) 或運算(||)

介入運算的兩個量只需有一個為真,成果就為真;兩個量都為假時,成果為假。例如:

10 || 0

10為真,0為假,相或的成果為真,也就是 1。

(5>0) || (5>8)

5>0 的成果是1,為真,5>8 的成果是0,為假,所以相或的成果為真,也就是1。

3) 非運算(!)

介入運算的量為真時,成果為假;介入運算的量為假時,成果為真。例如:

!0

0 為假,非運算的成果為真,也就是 1。

!(5>0)

5>0 的成果是1,為真,非運算的成果為假,也就是 0。

輸入邏輯運算的成果:

#include <stdio.h>
int main(){
 int a = 0, b = 10, c = -6;
 int result_1 = a&&b, result_2 = c||0;
 printf("%d, %d\n", result_1, !c);
 printf("%d, %d\n", 9&&0, result_2);
 printf("%d, %d\n", b||100, 0&&0);
 return 0;
}

 運轉成果:

0, 0
0, 1
1, 0

優先級

邏輯運算符和其它運算符優先級從低到高順次為:

賦值運算符(=) < &&和|| < 關系運算符 < 算術運算符 < 非(!)

&& 和 || 低於關系運算符,! 高於算術運算符。

依照運算符的優先次序可以得出:

a>b && c>d  等價於  (a>b)&&(c>d)
!b==c||d<a  等價於  ((!b)==c)||(d<a)
a+b>c&&x+y<b  等價於  ((a+b)>c)&&((x+y)<b)

別的,邏輯表達式也能夠嵌套應用,例如a>b && b || 9>c,a || c>d &&  !p。

邏輯運算符舉例:

#include <stdio.h>
int main(){
 char c='k';
 int i=1,j=2,k=3;
 float x=3e+5,y=0.85;
 printf( "%d,%d\n", !x*!y, !!!x );
 printf( "%d,%d\n", x||i&&j-3, i<j&&x<y );
 printf( "%d,%d\n", i==5&&c&&(j=8), x+y||i+j+k );
 return 0;
}

運轉成果:

0,0
1,0
0,1

本例中!x和!y分離為0,!x*!y也為0,故其輸入值為0。因為x為非0,故!!!x的邏輯值為0。對x|| i && j-3式,先盤算j-3的值為非0,再求i && j-3的邏輯值為1,故x||i&&j-3的邏輯值為 1。對i<j&&x<y式,因為i<j的值為1,而x<y為0故表達式的值為1,0相與,最初為0,對i==5&&c&&(j=8)式,因為i==5為假,即值為0,該表達式由兩個與運算構成,所以全部表達式的值為0。關於式x+ y||i+j+k因為x+y的值為非0,故全部或表達式的值為1。

以上就是對C說話邏輯運算符的常識整頓,願望能贊助進修C說話的同窗

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved