전체 글45 관계기반 알고리즘의 설계 알고리즘 설계법은 크게 두 가지가 있다. 1. 관계기반 설계 각 값들 사이의 관계를 이용하여 해를 구하는 방법 함수로 표현할 수 있어야 하며, 점화식같은 형태를 이용하여 표현 할 수 있어야 한다. 2. 탐색기반 설계 컴퓨터의 빠른 연산으로, 모든 집탑을 탐색하는 방법. 크기에 비래하여 시간이 길어질 수도 있다. 때문에 배제를 한다. ex) 1 ~ n 까지의 합 1) f(1) = 1;f(n) = f(n-1)+n; (n>=2) [출처] 알고리즘 심화 - 관계기반 알고리즘의 설계|작성자 bestmaker 1234567int f(int n){ if (n == 1) return 1; else return f(n - 1) + n;}cs 위와 같이 표현할 수 있겠다. 2) f(k) 를 n/2 로 가정 f(1) = 1.. 2016. 12. 18. 복사 생성자 12345678910111213141516171819202122232425262728293031#include #include #include class position{private: char *name; int age;public: position(char *aname, int age) { position::name = aname; position::age = age; } ~position() { puts("파괴"); }}; int main(void){ position a("갓코더", 17); position b = a;} Colored by Color Scriptercs 설명은 거두절미하고, 위의 코드가 정상적으로 돌아갈 것 같은가? 분명 컴파일은 성공적일 것이다. 하지만, 종료되고 파괴자가 실행되.. 2016. 7. 27. 파괴자 저번 글에 생성자가 객체 자체의 초기화외에 외부 환경까지 초기화 하기 때문에 객체가 사라질 떄 반대의 처리를 할 함수도 필요하다. 예를들어 다른 컴퓨텨와 연결했다면, 사라질 때 연결을 끊고 할당된 메모리도 반환해야 한다. 이러한 뒷처리를 하는 함수를 파괴자 라고 한다. 이 역시 객체가 소멸될 때 컴파일러가 자동으로 호출한다. 파괴자의 이름은 클래스 이름 앞에 ~를 붙인 것으로 고정되어 있으며 인수와 리턴 값은 가지지 않는다. 1234567891011121314151617181920212223242526272829303132333435363738#include #include #include class position{private: int x; int y; int *ptr;public: position(.. 2016. 7. 27. 생성자 클래스의 객체를 선언하면 메모리에 이 객체가 즉시 생성된다. 다만 클래스도 하나의 자료형인 만큼, 여느 변수처럼 할당만 되지 값이 있진 않다. 때문에 모두 쓰레기 값일 것이다. 그래서 초기화를 해줘야 한다. 만약1234567891011121314class position{public: int x; int y;}; int main(void){ position a; a.x = 10; a.y = 10;} cs이러한 코드가 있으면, 생성할 때마다 위의 코드와 같은, 변수를 하나 하나 초기화 해야 하는 번거로움이 있을 것이다. 이래서 등장한 것이 생성자이다. 생성자는 객체를 초기화 하기 위해서 존재한다. 우리가 int a = 5를 하는 것 처럼 position a(10, 10);을 하면 a라는 position클래.. 2016. 7. 27. 이전 1 2 3 4 5 ··· 12 다음