1,C语言 运算的顺序1、先说运算顺序 , 是从上到下,一句一句的算的 。从4行开始,赋值a1.b6.c3 。计算5行,q=a+b+c=1+6+3=10计算6行,a++ , a=a+1=2计算7行,++b,b=b+1=7计算8行,z=a+b+c=2+7+3=12执行9行,打印zabq分别是12.2.7.10注意第9行代码有错误,双引号内的z=……q=……a=……b=……顺序不对应该是z=……a=……b=……q=……2、asc码既能用八进制,也能用十进制表示 。只是在printf语句中 , 由转义符反斜杠"\"引导的asc码 , 必须用八进制数字表示 。错题,b没有定义!若写成int a=3;b=4;改成int a=3,b=4;,则表达式a+b%(a+b)/a+a*b-b的值是12——3+4%7/3+12-4=3+4/3+12-4=3+1+12-4=12 。先a/b再c/d 除了考虑优先级外 你还应该考虑结合性好一点的书上一般会有一张“ 操作符的优先极与结合性” 的表注:结合性 要么从左到右要么从右到左而 算术运算 + - * / 的结合性都市从左到右的 因此先 a/b 再c/d再 相加
2,c语言计算顺序就是四则运算计算顺序,先乘除后加减 。结果是10吧 。只是四则运算的话就是和数学运算时候的顺序一样的= < shift Left-to-right9 < 。譬如 ++*a也是先*后++ 。譬如 *a++ 就是先左后右 。所以所谓的左,因为*优先于++运算,但是顺序是从右往左了; <. ->> >,右;= %= += -= >* pointer-to-member Left-to-right6 * /,都是取决于运算符号的优先级别的.* ->= >! sizeof new delete unary (prefix) Right-to-left* & indirection and reference (pointers)+ - unary sign operator4 (type) type casting Right-to-left5 : conditional Right-to-left17 = *= /:: scope Left-to-right2 () []。具体的列表如下;= relational Left-to-right10 == 这要看运算符的优先级;< 。1 != assignment Right-to-left18 ; > ++ -- dynamic_cast static_cast reinterpret_cast const_cast typeid postfix Left-to-right3 ++ -- ~ != equality Left-to-right11 & bitwise AND Left-to-right12 ^ bitwise XOR Left-to-right13 | bitwise OR Left-to-right14 && logical AND Left-to-right15 || logical OR Left-to-right16 , comma Left-to-right这样可以么;><= &= ^= ?; % multiplicative Left-to-right7 + - additive Left-to-right8 <
3 , c语言运算顺序首先?是一个三目运算符 。格式为:a>b?a:b;意思是a如果前面的逻辑式为真,结果为a,为假结果是ba=x>0?3*x:x=10; 逻辑运算比赋值运算优先等级更高 , 所以a=这里就是把后面的结果赋值给a所以这里先看:x>0已知x=2;所以这里为真;输出冒号前面的x,x=2 。再把2赋值给a , 所以结果是2.a=x>0?3*x:x=10;问号运算符,是三目运算符 。如果x>0 , 则a=3*x,否则x=10,并将值赋给a2>0,因此x仍为2,a=3*x=3*2=6输出x的值,输出2这要看运算符的优先级 。譬如 *a++ 就是先左后右,因为*优先于++运算 。譬如 ++*a也是先*后++ , 但是顺序是从右往左了 。所以所谓的左,右,都是取决于运算符号的优先级别的 。具体的列表如下 。1 :: scope left-to-right2 () [] . -> ++ -- dynamic_cast static_cast reinterpret_cast const_cast typeid postfix left-to-right3 ++ -- ~ ! sizeof new delete unary (prefix) right-to-left* & indirection and reference (pointers)+ - unary sign operator4 (type) type casting right-to-left5 .* ->* pointer-to-member left-to-right6 * / % multiplicative left-to-right7 + - additive left-to-right8 << >> shift left-to-right9 < > <= >= relational left-to-right10 == != equality left-to-right11 & bitwise and left-to-right12 ^ bitwise xor left-to-right13 | bitwise or left-to-right14 && logical and left-to-right15 || logical or left-to-right16 ?: conditional right-to-left17 = *= /= %= += -= >>= <<= &= ^= != assignment right-to-left18 , comma left-to-right【c语言算式顺序,C语言 运算的顺序】
4,C语言中运算顺序好多啊谁帮忙总结一下谭浩强C语言书附录里面很详细:除了单目运算符、条件、赋值这三种运算符的结合性是从右向左,其他都是从左向右优先级的顺序(从高到低):括号下标结构体() [] -> .非反增减负类型! ~ ++ -- - (类型)指针地址与长度 * & sizeof算术移位关系* / % + ->> <<== >= <= > <位与异或或与或 & ^ | || &&条件赋值逗号 ?: = += -+ >>= <<=,http://www.slyar.com/blog/c-operator-priority.html运算符结合方式() [] -> .由左向右! ~ ++ -- + -* & (类型) sizeof由右向左* / %由左向右+ -由左向右<< >>由左向右< <= >= >由左向右== !=由左向右&由左向右^由左向右|由左向右||由左向右? :由右向左= += -= *= /=&= ^= |= <<= >>=由右向左,由左向右C语言的某位标准制定者曾经建议过:只要记住括号优先,乘除先于加减这两条准则就行了.优秀的程序员是不会写过于复杂,让人难以读懂的表达式的楼上几位讲的结合性与优先级的问题搞明白了后,推荐你看我的百度知道回答会对c语言有更深的理解5,帮我说说这个C语言的运算顺序吧拜托了、x+=x-=x+x ,表达式2是将i 的值加一个,先将1赋值给变量i; 这是赋值运算符,运算顺序是从右到左 。即先将x+x的值减赋给x变量(x-=x+x,即x=7-14=-7) , 再将x+=-7所以x的最终的值为-7+-7为-142、k=(i=1 。所以将2的值赋值给变量k,所以k的值为2 k=i=1,++i,i++;这个是由逗号运算符组成的表达式语句,将变量i的值赋给变量k (此时i和k的值都为1,++i,i++);这是将括号中的值计算出来后再赋值给变量k , i=1,++i,i++从左向右运算,将最后一个表达式的值作为这个逗号运算符组成的表达式的值,该值为2 (但i的值变成3)这类题没有实际意义 , 让别人怎么办,太容易出错了,写出这种代码来会不又能怎样会c++的c应该更没问题啊 楼上都把要点说过了 #include #include #include typedef struct data { int num; int secret; }typedata; typedef struct node { typedata data; struct node *next; }listnode; typedef listnode *linklist; linklist head; listnode *creat() { int n,j,b; linklist head=(listnode *)malloc(sizeof(listnode)); listnode *q; printf("输入总人数:"); scanf("%d",&n); fflush(stdin); q=head; for(j=1;j<=n;j++) { printf("请输入第%d号同学的密码:\n",j); scanf("%d",&b); fflush(stdin); printf("\n"); q->next=(listnode *)malloc(sizeof(listnode)); q=q->next; q->data.secret=b; q->data.num=j; q->next=head->next; } return(head); } void output(listnode *head,int m) { int i; listnode *p,*q; q=head; do { if(m<=0) { printf("输入错误"); exit(0); } i=1; while(i!=m) { q=q->next; i++; } p=q->next; q->next=p->next; printf("num:%d secret:%d\n",p->data.num,p->data.secret); m=p->data.secret; free(p); } while(q->next!=q); printf("num:%d secret:%d\n",q->data.num,q->data.secret); free(q); free(head); } int main() { int m=20; listnode *a; a=creat(); printf("请任意输入一个数m:"); scanf("%d",&m); fflush(stdin); output(a,m); printf("joseph环结束,欢迎下次使用\n"); system("pause"); return 0; } 貌似楼上那位output函数输出语句没看仔细,循环里面是p , 之后才是q
推荐阅读
- 苹果软件app,苹果下载软件有哪些
- ios公开版和开发者测试版,苹果ios12公测版和测试版的区别
- mysql数据库如何升级 mysqlclient怎么升级
- 分析家与飞狐专业板对比
- 苹果平板ipad最新款,ipad平板电脑价格
- mysql怎么查询实际收入情况 mysql怎么查询实际收入
- F200抗冻试块留置数量要求,趴趴狗行车记录仪F200为什么常亮?
- 6127爱情数字是什么意思
- mysql的备份文件在哪里 mysqlwindows备份