This file is indexed.

/usr/include/ColPack/BipartiteGraphVertexCover.h is in libcolpack-dev 1.0.9-3.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
/************************************************************************************
    Copyright (C) 2005-2008 Assefaw H. Gebremedhin, Arijit Tarafdar, Duc Nguyen,
    Alex Pothen

    This file is part of ColPack.

    ColPack is free software: you can redistribute it and/or modify
    it under the terms of the GNU Lesser General Public License as published
    by the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.

    ColPack is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU Lesser General Public License for more details.

    You should have received a copy of the GNU Lesser General Public License
    along with ColPack.  If not, see <http://www.gnu.org/licenses/>.
************************************************************************************/

using namespace std;

#ifndef BIPARTITEGRAPHVERTEXCOVER_H
#define BIPARTITEGRAPHVERTEXCOVER_H

namespace ColPack
{
	/** @ingroup group22
	 *  @brief class BipartiteGraphVertexCover in @link group22@endlink.

	 The bipartite graph bicoloring algorithms included in ColPack are variations of greedy, star and
	 acyclic bicolorings combined with explicit and implicit vertex coverings and guided by pre-computed vertex
	 orderings. The row and column vertices are initalized with two default colors, which are generally the color 0
	 for row vertices and for column vertices the color equal to one more than the sum of the numbers of row and
	 column vertices. The vertices whose colors are subsequently changed by the algorithms constitute a vertex
	 cover for the bipartite graph. The goal is to get the smallest vertex cover that can be colored to conform to
	 the bicoloring constraints. The computation of vertex cover has given rise to two types of algorithms, in one
	 of which a specialized vertex cover is computed explicitly for consumption by bicoloring algorithms and in
	 the other implicitly within the bicoloring algorithms. The bipartite graph covering class provides methods
	 for explicitly computing these specialized vertex covers.
	*/
	class BipartiteGraphVertexCover : public BipartiteGraphInputOutput
	{

	protected:

		double m_d_CoveringTime;

		vector<int> m_vi_IncludedLeftVertices;
		vector<int> m_vi_IncludedRightVertices;

		vector<int> m_vi_CoveredLeftVertices;
		vector<int> m_vi_CoveredRightVertices;

	public:

		//Public Constructor 3351
		BipartiteGraphVertexCover();

		//Public Destructor 3352
		~BipartiteGraphVertexCover();

		//Virtual Function 3353
		virtual void Clear();

		//Virtual Function 3354
		virtual void Reset();

		//Public Function 3355
		int CoverVertex();

		//Public Function 3356
		int CoverVertex(vector<int> &);

		//Public Function 3357
		int CoverMinimalVertex();

		//Public Function 3358
		void GetIncludedLeftVertices(vector<int> &output);

		//Public Function 3359
		void GetIncludedRightVertices(vector<int> &output);

		//Public Function 3360
		void GetCoveredLeftVertices(vector<int> &output);

		//Public Function 3361
		void GetCoveredRightVertices(vector<int> &output);

		//Public Function 3362
		void PrintBicoloringVertexCover();

	};
}
#endif