[求c语言中各类运算符的优先级别]c/C++的优先级 优先级 操作符 结合性 1 :: 左 2 . ->; [] () 左 3 ++ -- ~ ! - + & * () sizeof new delete castname_cast<type>; 单目操作符 右 4 .* ->;* 左 5 * / % 左...+阅读
1、“按位与”运算符(&) 按位与是指:参加运算的两个数据,按二进制位进行“与”运算。如果两个相应的二进制位都为1,则该位的结果值为1;否则为0。这里的1可以理解为逻辑中的true,0可以理解为逻辑中的false。按位与其实与逻辑上“与”的运算规则一致。逻辑上的“与”,要求运算数全真,结果才为真。若,A=true,B=true,则A∩B=true 例如:3&5 3的二进制编码是11(2)。(为了区分十进制和其他进制,本文规定,凡是非十进制的数据均在数据后面加上括号,括号中注明其进制,二进制则标记为2)内存储存数据的基本单位是字节(Byte),一个字节由8个位(bit)所组成。位是用以描述电脑数据量的最小单位。二进制系统中,每个0或1就是一个位。将11(2)补足成一个字节,则是00000011(2)。5的二进制编码是101(2),将其补足成一个字节,则是00000101(2) 按位与运算:00000011(2)&00000101(2)00000001(2) 由此可知3&5=1 c语言代码:#includemain() { int a=3; int b = 5; printf("%d",a&b); } 按位与的用途:(1)清零 若想对一个存储单元清零,即使其全部二进制位为0,只要找一个二进制数,其中各个位符合一下条件:原来的数中为1的位,新数中相应位为0。然后使二者进行&运算,即可达到清零目的。例:原数为43,即00101011(2),另找一个数,设它为148,即10010100(2),将两者按位与运算:00101011(2)&10010100(2)00000000(2) c语言源代码:#includemain() { int a=43; int b = 148; printf("%d",a&b); } (2)取一个数中某些指定位:若有一个整数a(2byte),想要取其中的低字节,只需要将a与8个1按位与即可。a 00101100 10101100 b 00000000 11111111 c 00000000 10101100 (3)保留指定位:与一个数进行“按位与”运算,此数在该位取1。例如:有一数84,即01010100(2),想把其中从左边算起的第3,4,5,7,8位保留下来,运算如下:01010100(2)&00111011(2)00010000(2) 即:a=84,b=59 c=a&b=16 c语言源代码:#includemain() { int a=84; int b = 59; printf("%d",a&b); }2、“按位或”运算符(|) 两个相应的二进制位中只要有一个为1,该位的结果值为1。借用逻辑学中或运算的话来说就是,一真为真。例如:60(8)|17(8),将八进制60与八进制17进行按位或运算。00110000 |0000111100111111 c语言源代码:#includemain() { int a=060; int b = 017; printf("%d",a|b); } 应用:按位或运算常用来对一个数据的某些位定值为1。例如:如果想使一个数a的低4位改为1,则只需要将a与17(8)进行按位或运算即可。3、“异或”运算符(^) 他的规则是:若参加运算的两个二进制位值相同则为0,否则为1 即0∧0=0,0∧1=1,1∧0=1, 1∧1=0 例: 00111001 ∧ 0010101000010011 c语言源代码:#includemain() { int a=071; int b = 052; printf("%d",a^b); } 应用:(1)使特定位翻转设有数01111010(2),想使其低4位翻转,即1变0,0变1.可以将其与00001111(2)进行“异或”运算。即:01111010 ^0000111101110101 运算结果的低4位正好是原数低4位的翻转。可见,要使哪几位翻转就将与其进行∧运算的该几位置为1即可。(2)与0相“异或”,保留原值 例如:012^00=01200001010 ^0000000000001010 因为原数中的1与0进行异或运算得1,0^0得0,故保留原数。(3) 交换两个值,不用临时变量 例如:a=3,即11(2);b=4,即100(2)。想将a和b的值互换,可以用以下赋值语句实现:a=a∧b; b=b∧a; a=a∧b; a=011(2) (∧)b=100(2) a=111(2)(a∧b的结果,a已变成7) (∧)b=100(2) b=011(2)(b∧a的结果,b已变成3) (∧)a=111(2) a=100(2)(a∧b的结果,a已变成4) 等效于以下两步:① 执行前两个赋值语句:“a=a∧b;”和“b=b∧a;”相当于b=b∧(a∧b)。② 再执行第三个赋值语句: a=a∧b。由于a的值等于(a∧b),b的值等于(b∧a∧b),因此,相当于a=a∧b∧b∧a∧b,即a的值等于a∧a∧b∧b∧b。c语言源代码:#includemain() { int a=3; int b = 4; a=a^b; b=b^a; a=a^b; printf("a=%d b=%d",a,b); }4、“取反”运算符(~) 他是一元运算符,用于求整数的二进制反码,即分别将操作数各二进制位上的1变为0,0变为1。例如:~77(8) 源代码:#includemain() { int a=077; printf("%d",~a); }5、左移运算符(
以下为关联文档:
C语言四则运算程序高手帮帮忙#include<stdio.h> #include<stdlib.h> #include<time.h> #include<string.h> int scan() { char s[100]; int i,t,z=0; do { z=0; gets(s); for(i=0;s[i]!='\0';i++) if(s[...
C语言四则运算程序高手帮帮忙!#include #include #include #include int scan() { char s[100]; int i,t,z=0; do { z=0; gets(s); for(i=0;s[i]!='\0';i++) if(s[i]'9') break; if(i>=strlen(s)) for(t=...
C语言问题四则运算程序我怀疑你代码的这段有问题: else if(ch == ')') { optr = MathOptr(ch); while(!Stack1Empty(&OptrStack) & Peek1(&OptrStack).stackprecedence >= optr.inputprecedence) //...
四则运算 c语言编程#include "stdio.h" #include "stdlib.h" #include "ctype.h" int n=0; char record[20]; float product(); float change(); float muli() { float summ; summ=product(); while(...
求c语言编写四则运算程序#include"stdafx.h" #include #include #include char token;/*global token variable*/ /*function prototypes for recursive calls*/ float exp(void); float term(void);...
用c语言编四则运算用C++写的,用C的话,函数方面很繁琐... 实现不止是整数,小数也可以,但算式中不要有负数,结果中可以有. 2000字不够用,分两部分,前一部分一些全局变量和类的申明: #include #include #...
C语言四则运算怎样编程呀如果只要最简单的那种计算(就是只计算+-*/并且只是输入X*X这样的式子)的话 直接用SWITCH就可以了 main() { float a,b,sum; char c; scanf("%f%c%f",&a,&c,&b); switch(c) { cas...
C语言编写程序四则运算法则1234567891011121314151617# include <stdio.h>int main(void){ int a,b,s; char c; scanf("%d%c%d",&a,&c,&b); switch(c) { case '+':s=a+b;break; case '-':s=a-b;break; c...
C语言。编写函数实现对字符串的赋值运算编写main函数如果是赋值运算要用C++ 的运算符重载,如果只是实现赋值操作还是可以的,例如: #include#includevoid main() { void mystrcpy(char *,char *); char res[20],obj[20]; mystrcpy(...