Python与C++ 程序的简单实例对比

2016-02-19 12:35 7 1 收藏

下面图老师小编跟大家分享一个简单易学的Python与C++ 程序的简单实例对比教程,get新技能是需要行动的,喜欢的朋友赶紧收藏起来学习下吧!

【 tulaoshi.com - 编程语言 】

一位网友正在学校做课程设计题目,要求在一个文件中找到给定单词出现的位置并统计出现次数。这是一个比较简单的文本处理问题, 于是, 我给他用 python 写了一个,并打赌在5分钟内用不到30行程序解决问题。 下面是程序: if __name__=='__main__':
  
  file_name = raw_input('Input the file you want to find in:')
  
  try:
  
  in_file = open(file_name,'r')
  
  lines = in_file.readlines()
  
          tag_tok = ''
  
  while tag_tok.upper() != 'Q':
  
  tag_tok = raw_input('Input the Word you want to find(Q for quit):')
  
  if tag_tok.upper() != 'Q':
  
  count = 0
  
  line_no = 0
  
  for line in lines:
  
  line_no = line_no + 1
  
  inline_cnt = line.count(tag_tok)
  
  count = count + inline_cnt
  
  if inline_cnt 0:
  
  print 'Find %s %d time(s) in line :%d'%(tag_tok,inline_cnt,line_no)
  
  print line
  
  print '---------------------------------'
  
  print 'Total fount %s %d time(s)'%(tag_tok, count)
  
  except:
  
  print "Can't open file %s"%(file_name)但是,这个网友还不满足非要一个 C++的程序,理由是他们老师不会python , 正好我也想试试用C++解决和python做下对比:#include fstream
  
  #include iostream
  
  #include string
  
  #include vector
  
  #include algorithmusing namespace std;int BruteFind(const char *x, int m, const char *y, int n ,vectorint& colpos) {
  
  int i, j, cnt=0;
  
  /* Searching */
  
  for (j = 0; j = n - m; ++j) {
  
  for (i = 0; i m && x == y[i + j]; ++i);
  
  if (i = m){
  
  colpos[cnt++] = j;
  
  if(cnt == colpos.size())
  
  colpos.resize(cnt * 2);
  
  }
  
  }
  
  return cnt;
  
  }int count_string(string source, string tag, vectorint& colpos){
  
  int find_cnt = 0;
  
  find_cnt = BruteFind(tag.c_str(), tag.size(), source.c_str(),source.size(),colpos);  return find_cnt;
  
  }int main(){
  
  string file_name, line;
  
  vectorstring lines;
  
  lines.resize(10);
  
  
  
  cout "Input the file name:";
  
  cin   file_name;
  
  ifstream in_file;
  
  try{
  
  in_file.open(file_name.c_str());
  
  if(!in_file)
  
  throw(file_name);
  
  }
  
  catch(string file_name){
  
  cout "Fatal error: File not found."endl;
  
  exit(1);
  
  }int line_count = 0;
  
  do{
  
  getline(in_file, lines[line_count]);
  
  line_count ++;
  
  
  
  if(line_count == lines.size()){
  
  lines.resize(line_count * 2);
  
  }
  
  }while(in_file.eof()==0);
  
  string tag_tok;
  
  vectorint colpos;
  
  colpos.resize(10);
  
  do{
  
  cout "Input the word you want to find(Q for quit):";
  
  cin tag_tok;
  
  if(tag_tok == "Q"){
  
  break;
  
  }
  
  
  
  int count = 0, line_no = 0 , inline_count;
  
  for(line_no = 0 ;line_no line_count ; line_no++){
  
  inline_count = count_string(lines[line_no], tag_tok, colpos);
  
  count += inline_count;
  
  if(inline_count 0){
  
  cout "Find " tag_tok " " inline_count " time(s) in line " line_no ;
  
  cout " , column pos is ( ";
  
  
  
  for(int i = 0 ;i inline_count ;i++){
  
  cout colpos ' ';
  
  }
  
  cout " )" endl;
  
  cout lines[line_no] endl;
  
  }
  
  }
  
  cout "--------------------------------" endl;
  
  cout "Total fount " tag_tok " " count " time(s)" endl;
  
  }while(tag_tok != "Q");
  
  in_file.close();
  
  return 0;
  
  }
   这个程序用了30分钟。从程序长度和编程时间上,粗略对比下:Python  5 分钟 22行C++       30 分钟 60多行从这个简单的例子中可以大体看到 脚本语言与C++语言中在开发时的差异了。

来源:http://www.tulaoshi.com/n/20160219/1601258.html

延伸阅读
1. 用Microsoft Visual C++ 6.0编译的程序,或者发布在Windows 2000/NT/ME/98 系统 单纯通过拷贝MSVCRxx.DLL文件到应用程序目录或system32目录即可 2. 用Visual Studio 2005以上编译的程序,且发布在Windows XP及以上系统 为了减少DLL引发的配置问题(DLL hell),C和C++运行时由并行 (Side-by-Side) 程序集实现,单纯通过拷贝MSVCRxx.DLL并不...
程序风格的要素-C++风格指南 原著:Neill Kipp 翻译:Panic 2005年3月30日 译者序: 这是一篇写于1996年1月23日的文章,到现在已经有9个年头了,很陈旧,有可能跟不上形势,但是有些东西仍然值得现在的开发者学习,我翻译这篇文字仅供读者参考。 原文链接:http://www.gamedev.net/reference/art...
Microsoft Developer Studio为大多数标准的数据库格式提供了32位ODBC驱动器。这些标准数据格式包括有:SQL Server、Access、Paradox、dBase、FoxPro、Excel、Oracle以及Microsoft Text。如果用户希望使用其他数据格式,则需要安装相应的ODBC驱动器及DBMS。 用户使用自己的DBMS数据库管理功能生成新的数据库模式后,就可以使用ODBC来登录...
简介 C++/CLI代表 ISO-C++标准语言的一个动态编程泛型扩展 (dynamic programming paradigm extension)。在原版语言设计 (V1) 中有许多显著的弱点,我们觉得在修订版语言设计 (V2) 中已经修正了这些弱点。本文列举了 V1 版本语言的功能和它们在 V2 版本中的对应功能(如果存在);并指出了其对应功能不存在的构造。对于有兴趣的读者,可以查看附...
    Tray(托盘)是Windows9x任务条上的一个非凡区域,它的技术名称为“任务栏布告区”,一些软件(如金山词霸Ⅲ)运行时会在托盘上放置一个图标,使用户一眼就能知道这个程序正在后台运行,要想激活它也很轻易,通常只需单击一下这个图标即可,非常方便。 Tray的编程比较非凡,但并不难,主要包括图标、工具提示和消...

经验教程

904

收藏

62
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部