일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 락
- 스케줄링
- 쓰레드
- 동적계획법
- 멀티쓰레드
- 운영체제
- Direct12
- 멀티프로세서
- 그리디알고리즘
- 다이나믹 프로그래밍
- 파일시스템 구현
- 프로그래머스
- DirectX12
- 백준
- 그리디 알고리즘
- 영속성
- 타입 객체
- 병행성
- 다이나믹프로그래밍
- 컨디션 변수
- DirectX 12
- codility
- 자료구조
- OS
- 알고리즘
- 디자인패턴
- 병행성 관련 오류
- 렌더링 파이프라인
- I/O장치
- directx
Archives
- Today
- Total
기록공간
별찍기 - 10 (백준-2447) 본문
반응형
#include <iostream>
using namespace std;
class CStar
{
public:
CStar(){ }
~CStar()
{
if (m_ppArr) {
for (int i = 0; i < m_nCount; ++i) {
if (m_ppArr[i]) {
delete[] m_ppArr[i];
m_ppArr[i] = nullptr;
}
}
delete[] m_ppArr;
m_ppArr = nullptr;
}
}
public:
int GetCount() { return m_nCount; }
public:
void Solve(int x, int y, int num)
{
if (num == 1) {
m_ppArr[x][y] = '*';
return;
}
int divide = num / 3;
for (int i = 0; i < 3; ++i) {
for (int j = 0; j < 3; ++j) {
if (i == 1 && j == 1) {
}
else {
Solve(x + (i * divide), y + (j * divide), divide);
}
}
}
}
void InputAndAllocate()
{
cin >> m_nCount;
m_ppArr = new char*[m_nCount + 1];
for (int i = 0; i < m_nCount; ++i) {
m_ppArr[i] = new char[m_nCount + 1];
for (int j = 0; j < m_nCount; ++j) {
m_ppArr[i][j] = ' ';
}
}
}
void PrintStar()
{
for (int i = 0; i < m_nCount; ++i) {
for (int j = 0; j < m_nCount; ++j) {
cout << m_ppArr[i][j];
}
cout << endl;
}
}
private:
int m_nCount = 0;
char **m_ppArr = nullptr;
};
int main()
{
CStar g;
g.InputAndAllocate();
g.Solve(0, 0, g.GetCount());
g.PrintStar();
}
반응형
'Algorithm > 문제' 카테고리의 다른 글
로프 (백준 - 2217번) (0) | 2020.02.08 |
---|---|
회의실배정 (백준 - 1931번) (0) | 2020.02.08 |
동전 0 (백준 - 11047번) (0) | 2020.02.08 |
ATM (백준 - 11399번) (0) | 2020.02.08 |
하노이탑(백준-11729) (0) | 2019.07.26 |
Comments