File: pascal_triangle.h

package info (click to toggle)
dynare 4.4.3-3
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 41,356 kB
  • ctags: 15,842
  • sloc: cpp: 77,029; ansic: 29,056; pascal: 13,241; sh: 4,811; objc: 3,061; yacc: 3,013; makefile: 1,479; lex: 1,258; python: 162; lisp: 54; xml: 8
file content (51 lines) | stat: -rw-r--r-- 973 bytes parent folder | download | duplicates (4)
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
// Copyright (C) 2005, Ondra Kamenik

// $Id: pascal_triangle.h 762 2006-05-22 13:00:07Z kamenik $

#ifndef PASCAL_TRIANGLE_H
#define PASCAL_TRIANGLE_H

#include <vector>

namespace ogu {

	using std::vector;

	class PascalRow : public vector<int> {
		int k;
	public:
		PascalRow()
			: vector<int>(), k(1)
			{ push_back(2); }
		void setFromPrevious(const PascalRow& prev);
		void prolong(const PascalRow& prev);
		void prolongFirst(int n);
		void print() const;
	};

	class PascalTriangle {
		vector<PascalRow> tr;
	public:
		PascalTriangle()
			{tr.push_back(PascalRow());}
		PascalTriangle(const PascalTriangle& triang)
			: tr(triang.tr) {}
		const PascalTriangle& operator=(const PascalTriangle& triang)
			{ tr = triang.tr; return *this;}
		int noverk(int n, int k);
		void print() const;
	protected:
		void ensure(int n, int k);
		int max_n() const;
		int max_k() const;
	};
};

extern ogu::PascalTriangle ptriang;


#endif

// Local Variables:
// mode:C++
// End: