鱼C论坛

 找回密码
 立即注册
查看: 2519|回复: 5

[技术交流] 转篇帖子->学C/C++必看

[复制链接]
发表于 2012-2-18 01:54:46 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
学习编程的一些情况我真的深有感触,这次面试使我深深的体会到了失败但也收获
了很多。我要说的将分成三部分:  

  1.是我面试的具体经过  

  2.是由面试想到的  

  3.现今我应该做的。  

  当然这些话很大程度上是我个人的意见,不可能完全得到大家的赞同,所以在
某些观点上如果哪位朋友觉得跟我的有很大出入,请不要介意,也不要对我攻击,
就当我没有说过,欢迎和我联系共同探讨这些问题!我的EMAIL:wutao8@263.net  

  1.面试经过  

  大约在年前我接到了台湾瑞晟(Realtek)苏州公司的面试通知,通知我2月21日
到苏州工业园区面试,接到面试后的几天我把一些专业课温习了一遍,特别是C++和
数据结构,由于大学几年里,我一直专研这些方面,加上通过了高级程序员的考试
,对于一些常用的算法我差不多也达到了烂熟于胸的地步,当时的感觉是如果问了
我这些方面的问题我应该是没有问题的!  

  21日那天我被安排在4:30面试,由一位技术人员单独给我面试,在问了一些简
单的问题之后他给我出了一道编程题目,题目是这样的:  

  (由于具体面试的题目比较烦琐,我将其核心思想提取出来分解成了两个独立的
简单的问题,有可能问题分解的不当,请大家见谅,实际面试了一个的问题但比其
复杂很多,而且涉及一些高等数学变换)  

  1) 写一个函数计算当参数为n(n很大)时的值 1-2+3-4+5-6+7......+n  

  哼,我的心里冷笑一声!没想到这么简单,我有点紧张的心情顿时放松起来!


  于是很快我给出我的解法:  

  long fn(long n)  

  {  

  long temp=0;  

  int i,flag=1;  

  if(n<=0)  

  {  

  printf("error: n must > 0);  

  exit(1);  

  }  

  for(i=1;i<=n;i++)  

  {  

  temp=temp+flag*i;  

  flag=(-1)*flag;  

  }  

  return temp;  

  }  

  搞定!当我用期待的目光看着面试官的时候,他微笑着跟我说,执行结果肯定
是没有问题!但当n很大的时候我这个程序执行效率很低,在嵌入式系统的开发中,
程序的运行效率很重要,能让CPU少执行一条指令都是好的,他让我看看这个程序还
有什么可以修改的地方,把程序优化一下!听了这些话,我的心情当时变的有点沉
重,没想到他的要求很严格,之后我对程序进行了严格的分析,给出了改进了的方
案!  

  long fn(long n)  

  {  

  long temp=0;  

  int j=1,i=1,flag=1;  

  if(n<=0)  

  {  

  printf("error: n must > 0);  

  exit(1);  

  }  

  while(j<=n)  

  {  

  temp=temp+i;  

  i=-i;  

  i>0?i++:i--;  

  j++;  

  }  

  return temp;  

  }  

--  

  虽然我不敢保证我这个算法是最优的,但是比起上一个程序,我将所有涉及到
乘法指令的语句改为执行加法指令,既达到要题目的要求而且运算时间上缩短了很
多!而代价仅仅是增加了一个整型变量!但是我现在的信心已经受了一点打击,我
将信将疑的看者面试官,他还是微笑着跟我说:“不错,这个程序确实在效率上有
的很大的提高!”我心里一阵暗喜!但他接着说这个程序仍然不能达到他的要求,
要我给出更优的方案!天啊!还有优化!我当时真的有点崩溃了,想了一会后,我
请求他给出他的方案!然后他很爽快的给出了他的程序!  

  long fn(long n)  

  {  

  if(n<=0)  

  {  

  printf("error: n must > 0);  

  exit(1);  

  }  

  if(0==n%2)  

  return (n/2)*(-1);  

  else  

  return (n/2)*(-1)+n;  

  }  

  搞笑,当时我目瞪口呆,没想到他是这个意思,这么简单的代码我真的不会写
吗,但是我为什么没有往那方面上想呢!他说的没有错,在n很大很大的时候这三个
程序运行时间的差别简直是天壤之别!当我刚想开口说点什么的时候,他却先开口
了:“不要认为CPU运算速度快就把所有的问题都推给它去做,程序员应该将代码优
化再优化,我们自己能做的决不要让CPU做,因为CPU是为用户服务的,不是为我们


  程序员服务的!”多么精辟的语言,我已经不想再说什么了!接着是第二个问
题:  

  2). 他要求我用一种技巧性的编程方法来用一个函数实现两个函数的功能n为如
:fn1(n)=n/2!+n/3!+n/4!+n/5!+n/6!  

  fn2(n)=n/5!+n/6!+n/7!+n/8!+n/9! 现在用一个函数fn(int n,int flag)实现
,当flag为0时,实现fn1功能,如果flag为1时实现fn2功能!他的要求还是效率,
效率,效率!说实在话,如果我心情好的话我应该能给出一种比较好的算法,但我
那时真的没有什么心思再想了,我在纸上胡乱画了一些诸如6!=6*5!的公式后直截了
当的跟他说要他给出他的答案!面试官也没有说什么,给出了他的思路:  

  定义一个二维数组 float t[2][5]存入{{2!,3!,4!,5!,6!},{5!,6!,7!,8!,9!}
}然后给出一个循环:  

  for(i=0;i<6;i++)  

  {  

  temp=temp+n/t[flag];  

  }  

  最后得到计算值!呵呵,典型的空间换时间的算法!  

  这些总共花了50分钟的时间,还有十分钟我就跟他很随意的聊聊天,聊了一些
编程以及生活的问题,那时的我已经很放松了,因为我知道这次面试结果只有一个
:失败。5:30的时候面试官要我等通知,于是我离开了他们公司。这就是面试的整
个经过!  

--  

  2.由面试想到的  

  真的是很失败啊!我记得那天下好大的雨,气温也很低,我边走边想,从5:30
一直走到7:30,全身都湿透了,又冷又饿,但是我只是一直走,脑子里面充满了疑
惑,我也想让雨把自己淋醒!看到这里有些朋友可能觉得那些面试题目不算什么如
果让自己做的话肯定能全部答对,我肯定相信你,因为我从未怀疑过中国程序员的
能力,我认为中国有世界上最好的程序员,我也从未认为自己是高手,所以我做不
出来不代表中国程序员比台湾或者别的地方的程序员差,所以我就从我的角度,我
的所见所想来谈一些感想:  

  不错全世界都有优秀的程序员,中国也不例外,但是我疑惑的是:到底中国和
台湾或者国外的优秀的程序员的比例到底是多少?台湾我不知道,中国100个程序员
里有几个是优秀的呢?我根本算不上,从上面的表现就足以说明一切了!是1个?5个
?10个?50个?这个数字我不敢乱猜,恐遭网友一顿痛骂,那么我们国内有多少人
学习计算机呢?拿我们学校来说,计算机97级4个班,98级5个班,99级10个班,20
00级17个班,人多了,老师怎么办?我们学校的做法是让研究生上课,然后呢?补
考一抓一大把,大把大把的补考费落入了学校的口袋,还说现在的学生素质低!真
是好笑,我都不知道学校这么做是为了什么,为国内培养大量的程序员吗?学生们
能真正学到计算机知识吗?好了,我敢讲,在我们学校学习编程学生和优秀程序员
(注意我指的是优秀,只会编几个糟烂程序的人算不上)的比例应该是100:0.1  
  
    在这种比例下虽然我们中国学习编程的人铺天盖地,但是想想有多少个人能真
正为中国软件业发展作出贡献,有多少人能真正写出优秀的程序名扬海外!  
  
    我从学习编程以来,不管是自学还是老师指导,从来都是解决问题就好,编出
程序来就行,我的疑惑是:我们有真正的强调过程序的效率,程序的质量吗?我们
有仔细分析过我们写的东西,看看有没有可以改进的地方,看看有没有简单的方法
来达到同样的目的呢?我问心自问,我发现,我从来没有对我写出来的程序进行过
优化,最多就是进行详细的测试,然后Debug,但是这就足够了吗?这些天我偶尔发
现我曾经写过的一个游戏,那是一年前我刚加入vcroad.net做为其中一员时候,感
觉应该拿点东西出来,然后花了一个星期的时间写出来的!程序不算复杂,但是用
到了不少数据结构的东西,也用到了一些精彩的算法,加上windows的界面和游戏的
可玩性,写完后受到了不少好评,我当时真的很佩服自己!但是现在看呢:没有一
句注释,好多丑陋的函数名比如:void chushihua(),好多没有必要的变量,可以
用简单语句完成工作的我使用华丽的算法,大量使用全局变量.....,说不好听的话
,六百多行的程序除了能运行之外就是一陀屎!如果一年前我能听到一些反面意见
的话,大概我能早一点觉悟,但是自从原代码在网站发布以来听到的都是赞美之词
,没有一个人向我提出程序改进的意见,这又说明了一个什么问题呢?很值得思考
啊!  

  还有一个疑惑是:我们说的和做的真的一样吗?我在学校的时候曾经受学院指
派承办过一个计算机大赛,请了一个老师出决赛的题目,主要是一些算法题目,这
个老师可能是我上大学以来唯一敬佩的老师了,从程序调试到打分,对于每个程序
都仔细分析其时间效率和空间效率,然后综合打分,四十个人的卷子,老师从下午
三点一直调试到晚上十点,在有些写的精彩的语句后还加上批注。我真是高兴很遇
到这样的老师并且和他做深入的交流,但在事后,却发生了一件不愉快的事,在比
赛中获得第二名的学生找到我,说他程序全部调试成功应该给他满分,并且应该得
第一,我说不过他,最后调出了他的原程序和第一名的原程序对比,不错,两个程
序都运行的很好,这时,那个同学开口了:“我的程序写的十分简捷明了,仅仅数
行就完成了题目要求,而他的却写了一大堆,为什么给他的分多过给我的分。”我
当时很是气愤,如果不是老师负责的话,那么现在第一名和第二名的位置真的要互
调了,拜托,不是程序的行数越少程序的质量就越高,我记得我跟他大谈这方面的
道理,最后说服他了!哈哈,但是我,只能说说而已,我不知道还有多少人一样,
说起来头头是道,但心里却压根就从未重视过它!  

3.我打算做的!  

  其实那天我想到的远不止上面那么多,但是我不想再说了,因为我猜想看这篇
文章的网友大概都有一肚子的感想,一肚子的抱怨,借用这篇文章发泄可不是我想
达到的目的,在上面我把自己骂的一文不值也不是妄自菲薄,但是在某些方面我真
的做错了,或者说是偏离了正确方向,现在是矫正方向和重整旗鼓的时候了,就象
我前面说过的,我相信中国有世界上最好的程序员,我也相信我的水平不会一直保
持现状,我现在就收拾起牢骚真正的实干起来!  

  真的很巧,就写到这里的时候我在网上偶尔发现了这篇手册,我不知道这预示
着什么,但是我想如果我照下面这个基本原则一直踏实做下去,我一定会实现我的
理想---一名优秀的软件设计师!  

  (下面这些文字不是我的原创,是我偶尔在网上发现的,我真的很幸运能看到
这些,这篇文章也随着下面的文字而结束,我真心的希望您能从这篇文章中得到启
发,这篇文章欢迎大家随意转载,您可以不写作者是谁,但是请您写上vcroad.net原
创,谢谢您的支持)  

  作者:金蝶中间件公司CTO袁红岗  

  不知不觉做软件已经做了十年,有成功的喜悦,也有失败的痛苦,但总不敢称
自己是高手,因为和我心目中真正的高手们比起来,还差的太远。世界上并没有成
为高手的捷径,但一些基本原则是可以遵循的。  

  1. 扎实的基础。数据结构、离散数学、编译原理,这些是所有计算机科学的基
础,如果不掌握他们,很难写出高水平的程序。据我的观察,学计算机专业的人比
学其他专业的人更能写出高质量的软件。程序人人都会写,但当你发现写到一定程
度很难再提高的时候,就应该想想是不是要回过头来学学这些最基本的理论。不要
一开始就去学OOP,即使你再精通OOP,遇到一些基本算法的时候可能也会束手无策
。  

  2. 丰富的想象力。不要拘泥于固定的思维方式,遇到问题的时候要多想几种解
决问题的方案,试试别人从没想过的方法。丰富的想象力是建立在丰富的知识的基
础上,除计算机以外,多涉猎其他的学科,比如天文、物理、数学等等。另外,多
看科幻电影也是一个很好的途径。  

  3. 最简单的是最好的。这也许是所有科学都遵循的一条准则,如此复杂的质能
互换原理在爱因斯坦眼里不过是一个简单得不能再简单的公式:E=mc2。简单的方法
更容易被人理解,更容易实现,也更容易维护。遇到问题时要优先考虑最简单的方
案,只有简单方案不能满足要求时再考虑复杂的方案。  

  4. 不钻牛角尖。当你遇到障碍的时候,不妨暂时远离电脑,看看窗外的风景,
听听轻音乐,和朋友聊聊天。当我遇到难题的时候会去玩游戏,而且是那种极暴力
的打斗类游戏,当负责游戏的那部分大脑细胞极度亢奋的时候,负责编程的那部分
大脑细胞就得到了充分的休息。当重新开始工作的时候,我会发现那些难题现在竟
然可以迎刃而解。  

  5. 对答案的渴求。人类自然科学的发展史就是一个渴求得到答案的过程,即使
只能知道答案的一小部分也值得我们去付出。只要你坚定信念,一定要找到问题的
答案,你才会付出精力去探索,即使最后没有得到答案,在过程中你也会学到很多
东西。  

  6. 多与别人交流。三人行必有我师,也许在一次和别人不经意的谈话中,就可
以迸出灵感的火花。多上上网,看看别人对同一问题的看法,会给你很大的启发。


  7. 良好的编程风格。注意养成良好的习惯,代码的缩进编排,变量的命名规则
要始终保持一致。大家都知道如何排除代码中错误,却往往忽视了对注释的排错。
注释是程序的一个重要组成部分,它可以使你的代码更容易理解,而如果代码已经
清楚地表达了你的思想,就不必再加注释了,如果注释和代码不一致,那就更加糟
糕。  

  8. 韧性和毅力。这也许是"高手"和一般程序员最大的区别。A good programm
ing is 99 weat and 1 offee。高手们并不是天才,他们是在无数个日日夜夜中磨
练出来的。成功能给我们带来无比的喜悦,但过程却是无比的枯燥乏味。你不妨做
个测试,找个10000以内的素数表,把它们全都抄下来,然后再检查三遍,如果能够
不间断地完成这一工作,你就可以满足这一条。  

  这些是我这几年程序员生涯的一点体会,希望能够给大家有所帮助。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
 楼主| 发表于 2012-2-18 02:05:26 | 显示全部楼层
  for(i=0;i<6;i++)  

  {  

  temp=temp+n/t[flag];  

  }  
改为sum = sum + n / *(t[flag] + i)
我读完这篇帖子感觉作者有点假
举的面试第一个例子有点太简单了 基本上会点数学很好总结那题规律
就像给你1 1 2 3 5 8这种组合找规律一样简单
面试公司好像也是大公司 可能就是简单测试下总结规律吧
还有作者的void chushihua()
有点夸张了 使过VC6能编个千百行代码的人也都熟悉这个单词了initialize
一般简写都init
不过作者意思就是代码命名规范些
现在程序都是讲究效率的 而非空间 一般都是空间换效率
就像10000阶乘 不优化5秒以上 优化1秒左右
这就是差距 做程序的人首先要保证程序的稳定(各种判定 各种释放)
然后代码的效率质量 希望对大家有帮助

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2012-2-18 10:50:52 | 显示全部楼层
思路,知识都不可缺,按部就班的人太多,看来还有编程思想问题!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2012-2-19 10:28:31 | 显示全部楼层
这个....好像N年以前看过....
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2015-11-13 11:00:40 | 显示全部楼层
学习了。。。。。, 话说楼主后来应聘上了吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-12-13 16:05:26 | 显示全部楼层
:handshake
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-26 16:52

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表