设为首页 收藏本站
查看: 715|回复: 0

[经验分享] 8皇后问题的c++与python实现对比

[复制链接]

尚未签到

发表于 2017-5-4 09:42:39 | 显示全部楼层 |阅读模式
c++经典书多,但貌似不太新,而python则新书很多,能体现一些新思路新概念。看python的书,写python代码,再用c++实现一遍,这样互补的学习方式貌似也蛮适合自己的。
在《Beginning Python From Novice to Professional》一书的八皇后问题上,python果然精妙而优雅。
在对待

  • foreachpossibilityatlevel1:
  • foreachpossibilityatlevel2:
  • foreachpossibilityatleveln:
  • ...
  • isitviable

形式的循环下,它有yield, generator递归。短短20来行代码就搞定了八皇后,如下:

  • defconflict(state,nextX):
  • nextY=len(state)
  • ifnextY==0:print0
  • foriinrange(nextY):
  • ifabs(nextX-state)in(0,nextY-i):
  • returnTrue
  • returnFalse

  • defqueen(num,state=()):
  • printstate
  • forposinrange(num):
  • ifnotconflict(state,pos):
  • iflen(state)==num-1:
  • yield(pos,)
  • else:
  • forresultinqueen(num,state+(pos,)):
  • yield(pos,)+result

  • defprettyprint(solution):
  • defline(pos,length=len(solution)):
  • return'.'*pos+'X'+'.'*(length-pos-1)
  • forposinsolution:
  • printline(pos)

  • if__name__=='__main__':
  • importrandom
  • prettyprint(random.choice(list(queen(4))))

其中

  • forresultinqueen(num,state+(pos,)):
  • yield(pos,)+result
2句由为精妙,自己苦思很久,没有能完全理解yield的精髓。。。。。

在用c++实现的时候,一直想模仿实现这句话的功能,却被这句话困扰了2个多小时,看书看久了不休息果然效率奇差。
今天早上醒来,才恍然大悟,其实不就是个栈么。

  • /*
  • *=====================================================================================
  • *
  • *Filename:eightqueen.cpp
  • *
  • *Description:8皇后问题,c++实现
  • *
  • *Version:1.0
  • *Created:2008年12月30日19时46分52秒
  • *Revision:none
  • *Compiler:gcc
  • *
  • *Author:LiWeiJian(mn),lwj1396@163.com
  • *Company:hunanuniversity
  • *
  • *=====================================================================================
  • */

  • #include<vector>
  • #include<iostream>
  • #include<cmath>
  • usingnamespacestd;

  • boolconflict(constvector<int>&state,intnextX)
  • {
  • intnextY=state.size();
  • for(inti=0;i<nextY;i++)
  • {
  • if(abs(nextX-state)==0||abs(nextX-state)==(nextY-i))
  • returntrue;
  • }
  • returnfalse;
  • }

  • voidqueen(intnum,vector<int>&state)
  • {
  • for(inti=0;i<num;i++)
  • {
  • state.clear();
  • state.push_back(i);
  • intpos=0;
  • while(state.size()!=num)
  • {
  • if(conflict(state,pos))//冲突了
  • {
  • if(pos==num-1)//已经是最后一个位置
  • {
  • state.pop_back();
  • break;
  • }
  • pos++;//尝试下一个pos
  • continue;
  • }
  • else//没有冲突
  • {
  • state.push_back(pos);
  • pos=0;
  • }
  • }
  • if(state.size()==num)
  • return;
  • }
  • }

  • voidprint(intnum,constvector<int>result)
  • {
  • for(inti=0;i<result.size();i++)
  • {
  • for(intj=0;j<result;j++)
  • cout<<".";
  • cout<<"X";
  • for(intj=0;j<num-result-1;j++)
  • cout<<".";
  • cout<<endl;
  • }
  • }

  • intmain()
  • {
  • vector<int>state;
  • queen(16,state);
  • print(16,state);
  • }



在实现之后,对比了一下,效率的差距果然满大,python跑14皇后,等了几分钟没搞定,而c++跑16皇后,都是刷的一下出来了,不过可能c++没有用递归也是一个原因。

最后再总结2句:
1 一本书,无论薄厚,都不能欺负它,不要想1,2天就看完
2 c++虽然经典,但书籍过老了,要拿一门有活力的语言为它开路,其实boost的c++已经很python了。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-372818-1-1.html 上篇帖子: python满足你需要的50个模块 下篇帖子: [转] Python的50个模块,满足你各种需要
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

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