社区
C++ 语言
帖子详情
++,--前缀后缀问题%%%%%%%%%%%%%%%%%
wxbaby
2008-03-24 11:02:44
都说++,--优先级比较高,起码比赋值"="要高对吧? 我看C++优先表上是这样的..
但为什么会,比如 : total=count++ +6;
COUNT的初始值是5,但TOTAL的值会是11,而不是12,
为什么不是先++完了再整个给赋值过去呢? 而是整个语句完了COUNT才自加的
...全文
103
16
打赏
收藏
++,--前缀后缀问题%%%%%%%%%%%%%%%%%
都说++,--优先级比较高,起码比赋值"="要高对吧? 我看C++优先表上是这样的.. 但为什么会,比如 : total=count++ +6; COUNT的初始值是5,但TOTAL的值会是11,而不是12, 为什么不是先++完了再整个给赋值过去呢? 而是整个语句完了COUNT才自加的
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
16 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
hanlin1985
2008-03-25
打赏
举报
回复
total=count++ +6;相当于total=((count++)+6);后置的++操作符先返回变量的当前值,然后在将自身加1,因此(count++)返回的结果是5,用5和6相加结果当然是11啦
wxbaby
2008-03-25
打赏
举报
回复
那个不是常数哦 我没说明清楚呵呵 是变量来着
关键我不懂这个
为什么不是先++完了再整个给赋值过去呢? 而是整个语句完了COUNT才自加的
hastings
2008-03-25
打赏
举报
回复
ho ho..
13楼说得对,当时没意识到.
wxbaby
2008-03-25
打赏
举报
回复
这么说后缀++运算要比赋值"="的优先等高啊?
真好 比老师说得都好
hiblackman
2008-03-25
打赏
举报
回复
[Quote=引用 1 楼 hastings 的回复:]
其实我对下列表达式的含义不是很懂:
total=count++ +6;
它到底是
total=(count++)+6;
还是
total=count+(++6);
若是前者,则为11,反之,为12
[/Quote]
不可能出现 ++6这种情况 6是
常量
taodm
2008-03-25
打赏
举报
回复
google 下载本《C专家编程》认真看看吧。
野男孩
2008-03-25
打赏
举报
回复
[Quote=引用 1 楼 hastings 的回复:]
其实我对下列表达式的含义不是很懂:
total=count++ +6;
它到底是
total=(count++)+6;
还是
total=count+(++6);
若是前者,则为11,反之,为12
[/Quote]
编译器从左至右,取最长的运算符。所以一定是(count++) + 6
hiblackman
2008-03-25
打赏
举报
回复
to 14楼:
无论是++a 还是 a++ (“++”就是自增运算符,不分什么前缀后缀)
这种自加减运算符的优先级都是“2”
赋值运算符“=”的优先级是“16” (谭浩强的c书附录里是“14”)
优先级数字越小 优先级越高
一般c/c++书的附录里都有运算符的优先级列表
hiblackman
2008-03-25
打赏
举报
回复
不是整个语句完了count才自加的,在你的例子中, 是做完了“+”运算之后 count自加1了
更详细的看这个
http://topic.csdn.net/t/20020420/11/662362.html
将++的处理和普通二维运算符的处理结合起来,让我们一步步看看(++i)+(++i)+(++i)是如何处理的。
i=3;
当处理先进行(++i)+处理,发现++i等级高,于是处理++i。特殊的情况发生了,这时++i的是对i本身相加,其结果并没有被压入堆栈。堆栈中仍为空,但i值却被更改为4。计算机继续处理i+(++i)。++的等级还是比+高。于是再度处理++。i的值再次被加了一。成了i+i+。因为++取地址运算的特殊性,令到这里的两个i的值都为5。同时堆栈还是没有数据。继续处理i+i+,两个优先级相同的运算符。i+i被执行,结果为10,结果被压入堆栈 st,成了st+(++i)。再执行是是执行++,i被加一成了6。于是为st+i。最后从堆栈中取出st==10和i==6相加。最后结果为 16。
当 a==10
--a 值为9
--a+(++a) 值为20
10+10=20
--a+(++a)+(--a) 值为29
10+10+9=29
--a+(--a)+(--a)+(++a) 值为31
8+8+7+8=31
++a+(--a)+(--a)+(++a)+(--a) 值为48
10+10+9+10+9=48
--a+(--a)+(++a)+(--a)+(--a)+(++a) 值为48
8+8+9+8+7+8=48
看到这里应该可以完全搞明白了。
搞清楚问题不是坏事,不过编程的时候少用。
hiblackman
2008-03-25
打赏
举报
回复
[Quote=引用 7 楼 wxbaby 的回复:]
那个不是常数哦 我没说明清楚呵呵 是变量来着
关键我不懂这个
为什么不是先++完了再整个给赋值过去呢? 而是整个语句完了COUNT才自加的
[/Quote]
因为
count++
和
++count
的编译过程是完全不同的。
total=
count++
+6 就是先用count的初始值"5" 去加6 然后才做 count+1
total=
++count
+6 才是先做 count+1 然后才去加6 (5+1)+6
zwl_19851220
2008-03-24
打赏
举报
回复
[Quote=引用 3 楼 w66187564 的回复:]
表达式实际上相当于:total=(count++)+6
count++的值为5 count的值为6
所以 total的值为 count++的值 加上 6
故为 11
如果写成total=++count+6 那值就为12了
[/Quote]
同意
des2006
2008-03-24
打赏
举报
回复
some bugs:
这种表达式,只有在面试的时候才会这样写。
平时编程,一般都会加上括号,避免歧义
des2006
2008-03-24
打赏
举报
回复
http://www.cppblog.com/aqazero/archive/2006/06/08/8284.html
先看看这个运算符优先级,再试着分析一下
++,--,的优先级要高于+,,+要高于=
另外这几个运算符都是从右至左结合
但是++是针对变量的,并不是针对常量的,所以应该是
total=(count++)+6;
++放在变量后面的时候,是先执行操作,再进行++运算;(如果放在变量前面,那就是先++,再执行操作)
就是这样分析
不知道对不对,明天到公司,再调试一下就知道了
w66187564
2008-03-24
打赏
举报
回复
表达式实际上相当于:total=(count++)+6
count++的值为5 count的值为6
所以 total的值为 count++的值 加上 6
故为 11
如果写成total=++count+6 那值就为12了
独孤过儿
2008-03-24
打赏
举报
回复
total=count++ +6;
它到底是
total=(count++)+6;
这种!
常值是不能有++或者--的
hastings
2008-03-24
打赏
举报
回复
其实我对下列表达式的含义不是很懂:
total=count++ +6;
它到底是
total=(count++)+6;
还是
total=count+(++6);
若是前者,则为11,反之,为12
相关推荐
java数据结构算法
做一门精致,全面详细的 java数据结构与算法!!!让天下没有难学的数据结构,让天下没有难学的算法,不吹不黑,我们的讲师及其敬业,可以看到课程视频,课件,代码的录制撰写,都是在深夜,如此用心,其心可鉴,他不掉头发,谁掉头发???总之你知道的,不知道的,我们都讲,并且持续更新,走过路过,不要错过,不敢说是史上最全的课程,怕违反广告法,总而言之,言而总之,这门课你值得拥有,好吃不贵,对于你知识的渴求,我们管够管饱话不多说,牛不多吹,我们要讲的本门课程内容:稀疏数组、单向队列、环形队列、单向链表、双向链表、环形链表、约瑟夫
问题
、栈、
前缀
、中缀、
后缀
表达式、中缀表达式转换为
后缀
表达式、递归与回溯、迷宫
问题
、八皇后
问题
、算法的时间复杂度、冒泡排序、选择排序、插入排序、快速排序、归并排序、希尔排序、基数排序(桶排序)、堆排序、排序速度分析、二分查找、插值查找、斐波那契查找、散列、哈希表、二叉树、二叉树与数组转换、二叉排序树(BST)、AVL树、线索二叉树、赫夫曼树、赫夫曼编码、多路查找树(B树B+树和B*树)、图、图的DFS算法和BFS、程序员常用10大算法、二分查找算法(非递归)、分治算法、动态规划算法、KMP算法、贪心算法、普里姆算法、克鲁斯卡尔算法、迪杰斯特拉算法、弗洛伊德算法马踏棋盘算法。
使用栈解决的一类经典
问题
:表达式转换及求值;中缀表达式;
前缀
表达式,
后缀
表达式,中缀转
前缀
;中缀转
后缀
;
后缀
表达式求值;波兰式,逆波兰式
文章目录背景知识表达式转换
问题
(考研经典)一:手工转换(1)中缀转
前缀
和中缀转
后缀
(2)
前缀
转中缀和
后缀
转中缀二:用栈实现表达式转换(1)中缀转
后缀
(2)中缀转
前缀
背景知识 中缀表达式:a+b
前缀
表达式(波兰式):+ab
后缀
表达式(逆波兰式):ab+ 表达式转换
问题
(考研经典) 一:手工转换 考研中有一类经典的
问题
就是表达式的转换
问题
,经常要把一个类型的表达式转换为另一个类型的表达式 所以这里我们主要说一下中缀转
前缀
,
前缀
转中缀,中缀转
后缀
和
后缀
转中缀即可。这样这三种形式任意两个之间的转换都可以借助
前端面试——KMP算法实例
问题
:已知主串S=“ababcabcacbab”,模式T=“abcac”。利用KMP算法进行匹配时,需要进行几次才可以匹配成功? 首先计算部分匹配值: abcac中: a的
前缀
为0,
后缀
为0,
前缀
和
后缀
重合的部分为0 ab的
前缀
为a,
后缀
为b,
前缀
和
后缀
重合的部分为0 abc的
前缀
为[a,ab],
后缀
为[bc,b],
前缀
和
后缀
重合的部分为0 abca的
前缀
为[a,ab,abc],
后缀
为[bca,ca,a],
前缀
和
后缀
重合的部分为1 abcac的
前缀
为[a,ab,abc,abca],
后缀
为[bcac,cac,
后缀
数组——height数组
说明:本文主要讲述
后缀
数组中的height数组,写
后缀
数组的一些题目时,发现大部分都要用到height数组,最长公共
前缀
就是height数组能求解的众多
问题
之一,本文通过对最长公共
前缀
的求解来讲述height数组,关于
后缀
数组的构造
问题
看这里:
后缀
数组的构造 最长公共
前缀
(Longest Common Prefix) 题目描述:给定一个字符串,求该字符串
后缀
a和
后缀
b的最长公共
前缀
定义he...
内功修炼之数据结构与算法
内容简介: 无论你是从事业务开发,还是从事架构设计,想要优化设计模式,数据结构与算法是必备的一门学科,本课程使用Java来讲解数据结构和算法,考虑到数据结构和算法较难,授课采用图解加算法游戏的方式。内容包括: 稀疏数组、单向队列、环形队列、单向链表、双向链表、环形链表、约瑟夫
问题
、栈、
前缀
、中缀、
后缀
表达式、中缀表达式转换为
后缀
表达式、递归与回溯、迷宫
问题
、八皇后
问题
、算法的时间复杂度、冒泡排序、选择排序、插入排序、快速排序、归并排序、希尔排序、基数排序(桶排序)、堆排序、排序速度分析、二分查找、插值查找、斐波那契查找、散列、哈希表、二叉树、二叉树与数组转换、二叉排序树(BST)、AVL树、线索二叉树、赫夫曼树、赫夫曼编码、多路查找树(B树B+树和B*树)、图、图的DFS算法和BFS、程序员常用10大算法、二分查找算法(非递归)、分治算法、动态规划算法、KMP算法、贪心算法、普里姆算法、克鲁斯卡尔算法、迪杰斯特拉算法、弗洛伊德算法马踏棋盘算法。为什么学数据结构与算法? 算法是一个程序员真正的核心竞争力。无论用哪种语言做开发,算法从程序角度而言都是灵魂内核般的存在。程序的躯体可以各式各样,但是内核一定要追求高效整洁。同时掌握了算法,大厂名企的Offer不再是梦寐以求的梦想,而让程序高效且健壮,也不再是难以完成的技术难题。所以无论是为提升自我内功修炼,还是提升程序灵魂内核健全,学习算法,都是现有可供选项里的最优解。课程大纲:为了让大家快速系统了解数据结构与算法知识全貌,我为你总结了「数据结构与算法框架图」,帮你梳理学习重点,建议收藏!! CSDN学院Java答疑群:
C++ 语言
63,596
社区成员
250,393
社区内容
发帖
与我相关
我的任务
C++ 语言
C++ 语言相关问题讨论,技术干货分享,前沿动态等
复制链接
扫一扫
分享
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++
技术论坛(原bbs)
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
请不要发布与C++技术无关的贴子
请不要发布与技术无关的招聘、广告的帖子
请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下