注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

Aspirer's blog

停止维护,新博客地址:http://aspirer.wang/

 
 
 

日志

 
 

C++输入输出缓冲区的刷新和流状态的控制  

2009-03-27 20:55:54|  分类: 学习心得 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

C++输入输出缓冲区的刷新和流状态的控制 - aspirer - Aspirers blog


/*
*closest_num.h
*给定一个数,从输入的一组数中找到与其距离最近的数,
*并输出其在输入的数组中的位置;
*/


#ifndef CLOSEST_NUM_H
#define CLOSEST_NUM_H

#include <iostream>
#include <vector>
#include <algorithm>
#include <math.h>
//#include <istream>

const bool comp( const double &a, const double &b )
{
 return fabs(a) < fabs(b) ;
}

class CN
{
private:
 double num ;
 std::vector < double > input_nums ;
public:
 //CN( ) : num( 0 )
 //{
  //std::vector < double > temp( 10 ) ;
  //input_nums = temp ;
 //}
 
 void GetNums( )
 {
  
  std::cin.clear() ;//重置输入流条件状态为全有效状态;
  fflush(stdin) ; //刷新残余输入流,也即清空输入流缓冲区;
  fflush(stdout) ;//刷新残余输出流,也即清空输出流缓冲区;
  std::cout << "输入被找数据:" ;
  std::cin >> num ;  
  
  double temp ;
  std::cout << "输入一组数据,以任意字符结束:" << std::endl ;
  while ( std::cin >> temp )
  {
   input_nums.push_back( temp ) ;  
  }
  
 }

 void FindClosestNum()
 {
  std::vector < double > temp1( input_nums ) ;
  std::vector < double > temp2( input_nums ) ;
  std::vector < double >::iterator tmp_it , tmp2_it ;
  for ( tmp_it = temp1.begin() , tmp2_it = temp2.begin() ;
    tmp_it != temp1.end() ;
    ++tmp_it, ++tmp2_it )
  {
   *tmp_it -= num ;
   *tmp2_it -= num ;
  }
  
  stable_sort( temp1.begin(), temp1.end(), comp ) ;
  std::vector < double >::const_iterator result1 ;
  result1 = find( temp2.begin(), temp2.end(), temp1[0] ) ;

  std::cout << "与" << num << "最接近的数为:" ;
  std::vector < double >::const_iterator it = temp2.begin() ;
  std::vector < double >::const_iterator result = input_nums.begin() ;
  int i = 1 ;
  for (  ; it != result1 ; ++it )
  {
   ++i ;
   ++result ;
  }
  std::cout << *result << ", 位于输入数据的第"
       << i << "位!" << std::endl ;

 }


 void FindClosestNum2()
 {
  std::vector < double > temp( input_nums ) ;
  std::vector < double >::iterator it ;
  for ( it = temp.begin() ; it != temp.end() ; ++it )
  {
   *it = fabs( *it - num ) ;
  }
  
  stable_sort( temp.begin(), temp.end() ) ;
  
  size_t pos = 1 ;
  for ( it = input_nums.begin() ; it != input_nums.end() ; ++it )
  {
   if ( fabs(*it - num) == *temp.begin() )
   {
    std::cout << "第二种算法:" << std::endl ;
    std::cout << "与" << num << "最接近的数为:"
         << *it << ",位于输入数据的第"
         << pos << "位!" << std::endl ;
    break ;
   }
   ++pos ;
  }
 }

};

 

#endif

 


/*

*主函数部分:

*/


#include "closest_num.h"
#include <iostream>
int main()
{
 CN cn1 ;
 cn1.GetNums() ;
 cn1.FindClosestNum() ;
 
 CN cn2 ;
 cn2.GetNums();
 cn2.FindClosestNum2() ;

 return 0 ;
}

 

 


注释掉红色字体部分试试看有什么问题。

这时你就会清楚的明白红色字体部分的作用了!

 

  评论这张
 
阅读(1793)| 评论(2)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018