TextQuery.h
上传用户:qdkongtiao
上传日期:2022-06-29
资源大小:356k
文件大小:3k
源码类别:

书籍源码

开发平台:

Visual C++

  1. /*
  2.  * This file contains code from "C++ Primer, Fourth Edition", by Stanley B.
  3.  * Lippman, Jose Lajoie, and Barbara E. Moo, and is covered under the
  4.  * copyright and warranty notices given in that book:
  5.  * 
  6.  * "Copyright (c) 2005 by Objectwrite, Inc., Jose Lajoie, and Barbara E. Moo."
  7.  * 
  8.  * 
  9.  * "The authors and publisher have taken care in the preparation of this book,
  10.  * but make no expressed or implied warranty of any kind and assume no
  11.  * responsibility for errors or omissions. No liability is assumed for
  12.  * incidental or consequential damages in connection with or arising out of the
  13.  * use of the information or programs contained herein."
  14.  * 
  15.  * Permission is granted for this code to be used for educational purposes in
  16.  * association with the book, given proper citation if and when posted or
  17.  * reproduced.Any commercial use of this code requires the explicit written
  18.  * permission of the publisher, Addison-Wesley Professional, a division of
  19.  * Pearson Education, Inc. Send your request for permission, stating clearly
  20.  * what code you would like to use, and in what specific way, to the following
  21.  * address: 
  22.  * 
  23.  *  Pearson Education, Inc.
  24.  *  Rights and Contracts Department
  25.  *  75 Arlington Street, Suite 300
  26.  *  Boston, MA 02216
  27.  *  Fax: (617) 848-7047
  28. */ 
  29. #ifndef TEXTQUERY_H
  30. #define TEXTQUERY_H
  31. #include <string>
  32. #include <vector>
  33. #include <map>
  34. #include <set>
  35. #include <iostream>
  36. #include <fstream>
  37. #include <cctype>
  38. #include <cstring>
  39. class TextQuery {
  40.     // as before
  41. public:
  42.     // typedef to make declarations easier
  43.     typedef std::string::size_type str_size;
  44.     typedef std::vector<std::string>::size_type line_no;
  45.     /* interface:
  46.      *    read_file builds internal data structures for the given file
  47.      *    run_query finds the given word and returns set of lines on which it appears
  48.      *    text_line returns a requested line from the input file
  49.     */
  50.     void read_file(std::ifstream &is) 
  51.                { store_file(is); build_map(); }
  52.     std::set<line_no> run_query(const std::string&) const; 
  53.     std::string text_line(line_no) const;
  54.     str_size size() const { return lines_of_text.size(); }
  55.     void display_map();        // debugging aid: print the map
  56. private:
  57.     // utility functions used by read_file
  58.     void store_file(std::ifstream&); // store input file
  59.     void build_map(); // associated each word with a set of line numbers
  60.     // remember the whole input file
  61.     std::vector<std::string> lines_of_text; 
  62.     // map word to set of the lines on which it occurs
  63.     std::map< std::string, std::set<line_no> > word_map;  
  64.     // characters that constitute whitespace
  65.     static std::string whitespace_chars;     
  66.     // canonicalizes text: removes punctuation and makes everything lower case
  67.     static std::string cleanup_str(const std::string&);
  68. };
  69. #endif