일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- Qt OpenGL
- 재귀함수
- 자바
- 윈도우7
- qt 설치
- 스타크래프트2
- 알람프로그램
- 스타2
- 오토바이
- 마영전
- QTcpServer
- FFI
- Qt 소켓프로그래밍
- 안드로이드
- android SAF
- Qt4
- 엑티브엑스
- HTML
- 이륜차
- 자료구조
- 바이크
- QT
- vuejs
- 정성하
- 양평역
- 잡담
- Java
- 디자이어HD
- 고속도로
- c언어
- Today
- Total
목록자료구조 (3)
프로그래밍과 잡담
단일 연결리스트와 다른건 struct Node{ int key; struct Node* left; struct Node* right; } 위와 같이 두개로 되어있다. 단일 연결리스트의 단점은 검색을 할때 뒤로 못가는데 이건 그게 가능해진다. 단일의 경우 뒤로 갈려면 환영구조로 해서 한바퀴 돌아서 오는 수 밖에는 없다. 그래서 주로 이중연결리스트를 많이 사용한다. 삽입과 삭제는 단일과 같기 때문에 안쓴다. left에 전 노드의 주소를 넣어주면 된기때문에 그 외에는 다른게 없다. 삭제 할때는 좀 더 편하다. 왜냐하면 찾는 노드가 전에 노드의 주소와 다음 노드의 주소를 가지고 있기때문에 ..바로 이어 줄 수 있다. 이중 ... 단일 노드 -> 노드 -> 노드 -> ...
단순 연결리스트의 기본 구조는 typedef struct _node{ int key; struct _node *next; }Node; 위와 같은 형식을 가진다. 단순연결이기때문에 검색을 할려면 앞에서부터 순차적으로 들어간다. 뒤로 가는건 안됀다 오로지 앞으로만 갈 수 있다. 뒤로갈려면 이중연결리스트를 써야한다. 연결리스트의 단점은 배열보다 용량을 더 잡아먹고, 주소를 잘못 지정하면 전에 있던거나 앞에 있던게 메모리 상에서 떠돌아다니게 된다. 뭔말인고 하니 메모리 누수가 생긴다는거다. 물론 C일 경우에만 Java나 C# 같은 GC(garbage collector)가 있는 랭귀지는 관계 없다. Head -> A - > B - > C - > D -> NULL C를 찾기 위해서는 Head 에서부터 C까지 들어가..
바로 자료구조.. 자료구조에 나오는건 바로 스택,큐, 링크드 리스트, 트리 사람들이 꽤나 어려워한다는 자료구조다.. 어려운 이유는.. 링크드리스트! 뭐 잘하놈들은 잘하지만 못하는 사람들은 꽤나 어려울꺼다.. 나야 전에 배워서 대충은 알지만..;; 그래도 좀 어려운건 사실.. 링크드 리스트의 구조는 이런식이다.. typedef struct _Node{ int key; struct _Node *next; }Node; 위와 같은 구조를 가진다. 구조체안에 자신의 구조체 포인터를 가지는 형태를 가진다.