A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 学习之路 中级黑马   /  2015-12-27 14:18  /  973 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

有如下程序,求result的值
#include<stdio.h>
void main(){
       int i=1;
       int j=1;
       int result=i+++j;
       printf("result=%d\n",result);  
}
假如我们根据自增的优先级及结合性,自己算出的值为3,而经程序运行得出的值为2,这样的情况便是贪心法则造成的。c语言有这样的一个规则:每一个符号应该包含尽可能多的字符.也就是说,编译器将程序分解成符号的方法是:从左到右一个一个字符地读入,如果此字符可能组成一个符号,那么再读入下一个字符,判断已经读入的两上字符组成的字符组成的字符串是否可能是一个符号的组成部分,如果可能,继续读入下一个字符,重复上述判断,直到读入的字符组成的字符串已不再可能组成一个有意义的符号.这个处理的策略被称为"贪心法".

2 个回复

倒序浏览
原来这叫做贪心法则啊,很形象的一个称呼
回复 使用道具 举报
yolande 来自手机 中级黑马 2015-12-28 12:44:17
藤椅
我以为是贪心算法。。。
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马