디시인사이드 갤러리

갤러리 이슈박스, 최근방문 갤러리

갤러리 본문 영역

횽들 연산자 오버로딩좀 알려주새요..

ㅠㅠ(121.187) 2012.03.31 16:02:01
조회 103 추천 0 댓글 0

#include <iostream>
#include <string>
#include <new>
#include <fstream>

using namespace std;

template <class ItemType>
struct Node
{
ItemType item;
Node<ItemType>* next;
};
template <class ItemType>
class SortedLinkedList
{
private:
int size;
Node<ItemType>* head;
Node<ItemType>* scanPos;
public:
SortedLinkedList();
~SortedLinkedList();
bool isEmpty() const;
bool isFull() const;
int getSize() const;
void insert(const ItemType& data, bool& success);
void remove(const ItemType& data, bool& found);
void retrieve(const ItemType& data, bool& found) const;
void reset();
void getNext(ItemType& data);
void print(ostream& out) const;
};
template <class ItemType>
SortedLinkedList<ItemType>::SortedLinkedList()
{
size = 0;
head = NULL;
}
template <class ItemType>
SortedLinkedList<ItemType>::~SortedLinkedList()
{
Node<ItemType>* tmp;
while (head != NULL)
{
tmp = head;
head = head->next;
delete tmp;
}
}
template <class ItemType>
bool SortedLinkedList<ItemType>::isEmpty() const
{
return size == 0;
}
template <class ItemType>
bool SortedLinkedList<ItemType>::isFull() const
{
Node<ItemType>* tmp;
try
{
tmp = new Node<ItemType>;
delete tmp;
return false;
}
catch (bad_alloc e)
{
return true;
}
}
template <class ItemType>
int SortedLinkedList<ItemType>::getSize() const
{
return size;
}
template <class ItemType>
void SortedLinkedList<ItemType>::insert(const ItemType& data, bool& success)
{
if (isFull())
{
success = false;
return;
}

Node<ItemType>* tmp; // 삽입할 노드에 대한 포인터
Node<ItemType>* prevNode = NULL; // 스캔하기 위한 포인터의 전포인터
Node<ItemType>* currNode = head; // 스캔하기 위한 포인터

tmp = new Node<ItemType>; // 새로운 노드 만들어 데이터 삽입
tmp->item = data;
tmp->next = NULL;

if (head == NULL) // 리스트가 비어있는 경우
{
head = tmp;
success = true;
size++;
return;
}

bool found = false; // 삽입할 위치를 찾으면 true
while (!found)
{
if (currNode->item < data)
{
prevNode = currNode;
currNode = currNode->next;
if (currNode == NULL)
found = true;
}
else
found = true;
}

if (prevNode == NULL) // 맨 앞에 삽입
{
tmp->next = head;
head = tmp;
}
else
{
tmp->next = currNode;
prevNode->next = tmp;
}

success = true;
size++;
}
template <class ItemType>
void SortedLinkedList<ItemType>::remove(const ItemType& data, bool& found)
{
if (isEmpty())
{
found = false;
return;
}

Node<ItemType>* tmp; // 삭제할 노드에 대한 포인터
Node<ItemType>* prevNode = NULL; // 스캔하기 위한 포인터의 앞 포인터
Node<ItemType>* currNode = head; // 스캔하기 위한 포인터

found = false; // 삭제할 위치를 찾으면 true
while (!found)
{
if (currNode->item == data)
{
found = true;
break;
}
else if (currNode->item < data)
{
prevNode = currNode;
currNode = currNode->next;
if (currNode == NULL) // 맨 끝 노드까지 갔으나 찾지 못함
return;
}
else // 데이터가 노드의 값보다 작은 경우 => 찾지 못함
return;
}

if (prevNode == NULL) // 맨 앞의 노드 삭제
{
tmp = head;
head = head->next;
delete tmp;
}
else
{
tmp = currNode;
prevNode->next = currNode->next;
delete tmp;
}

size--;
}
template <class ItemType>
void SortedLinkedList<ItemType>::retrieve(const ItemType& data, bool& found) const
{
found = false;
Node<ItemType>* tmp = head;

while (tmp != NULL && !found)
if (tmp->item == data)
found = true;
else
tmp = tmp->next;
}
template <class ItemType>
void SortedLinkedList<ItemType>::print(ostream& out) const
{
Node<ItemType>* tmp = head;
while (tmp != NULL)
{
out << tmp->item << endl;
tmp = tmp->next;
}
out << endl;
}
template <class ItemType>
void SortedLinkedList<ItemType>::reset()
{
scanPos = head;
}
template <class ItemType>
void SortedLinkedList<ItemType>::getNext(ItemType& data)
{
data = scanPos->item;
scanPos = scanPos->next;
}
int main()
{
StudentRecord s;
SortedLinkedList<int> intList;
SortedLinkedList<string> strList;
SortedLinkedList<StudentRecord> studentList;
bool success;

int num;
string str;
float flo;
ifstream infile;

infile.open("data.txt");
while(infile >> str)
{
num = atoi(str.c_str());
if(isdigit(str.c_str()[0]))
intList.insert(num, success);
else
strList.insert(str, success);
}
cout << "Integers in the list." << endl;
intList.print(cout);
cout << "Strings in the list." << endl;
strList.print(cout);

infile.close();

return 0;
}

이건 텍스트 파일에 랜덤하게 나열되있는 문자열이랑 숫자를 읽어서

문자열은 문자열끼리 숫자는 숫자끼리 정렬해서 출력하는건데 여기까진 됐거든..

근데 이제 학번, 학생 이름, 성적 이렇께 세개의 레코드가 있는 다른 텍스트 파일을 읽어서

그 학생들을 성적순으로 정렬한다음에 콘솔에 출력하려구 해

근데 내가 학생 클래스를 새로 만들어서 연결리스트에 넣으면 다른거랑 달리

학생클래스끼리는 비교를 못하니까 성적순으로 비교해서 정렬할 수 있게 해줘야 되는데

그걸 어덯게 해야될지를 모르겠서.. 알려조 횽들..

추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 뛰어난 운동 신경으로 남자와 싸워도 이길 것 같은 여자 스타는? 운영자 25/11/24 - -
AD 대학생 필수템! What's in my Bag 운영자 25/11/21 - -
공지 프로그래밍 갤러리 이용 안내 [97] 운영자 20.09.28 48749 65
2904422 요즘은 관리잘하면 50초중까지는 꼴리는듯 ㅇㅇ(118.235) 06:25 4 0
2904421 인지과학조져라 손발이시립디다갤로그로 이동합니다. 06:13 9 0
2904420 발명도둑잡기 차단이 왜 풀려있냐? ㅇㅇ(114.30) 06:11 11 0
2904418 중국인 댓글부대 한국여론조작 포착 ♥냥덩이의우웅한하룽♥갤로그로 이동합니다. 06:07 10 0
2904415 kqueue와 epoll의 시스템 아키텍처 및 설계 철학 비교 나르시갤로그로 이동합니다. 05:46 13 0
2904410 33살 중소3년차 똥통인생 이스펙으로 중견입사 가능하냐..? ㅇㅇ(118.235) 04:59 15 0
2904408 지잡대 졸업 30살인데 학벌 세탁원하는데 학사편입vs대학원 ㅇㅇ(203.232) 04:30 15 0
2904407 Claude cli 오늘 첨 써봤는데 개발자 왜 필요하냐 프갤러(101.235) 04:26 18 0
2904389 Clair.IO.Poller: 이번에 설계했다가 gg친 API ㅋㅋ 나르시갤로그로 이동합니다. 02:59 31 0
2904375 진짜 프로그래머들 ㅈㄴ부럽다 [2] ㅅ스맨갤로그로 이동합니다. 02:18 69 0
2904367 코딩 걍 첨부터 막히는데 어캄 [2] ㅅ스맨갤로그로 이동합니다. 01:54 50 0
2904364 자바 언어 좋지.. 추억과 낭만이 깃들인 언어 ㅋㅋ [1] 나르시갤로그로 이동합니다. 01:45 41 0
2904363 거래소 api들 잘 다루고 싶으면 뭐 부터 배우면 될까요 선배님들 [3] 프갤러(114.204) 01:43 35 0
2904362 7번국도 드라이빙 때 좋을만한 브금 chironpractor갤로그로 이동합니다. 01:31 20 0
2904359 0x [1] 루도그담당(58.233) 01:22 27 0
2904358 접시 ㅇㅅㅇ [6] 헤르 미온느갤로그로 이동합니다. 01:12 48 0
2904357 태연 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 01:09 20 0
2904356 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 01:08 30 0
2904324 오픈소스 프로젝트를 하나 해볼까 [12] 에이도비갤로그로 이동합니다. 00:02 89 0
2904320 고 언어 음 좋지 나쁘지 않고 효율적이고 음 근데 [6] 프갤러(110.8) 11.23 56 0
2904316 www.basic4mcu.com 11월까지 서비스 종료 발명도둑잡기(118.216) 11.23 18 0
2904313 카리나가 맛집이넹 ♥냥덩이의우웅한하룽♥갤로그로 이동합니다. 11.23 56 0
2904309 그러고 보니 프갤에서 고랭 팬은 못본거 같은데 [4] chironpractor갤로그로 이동합니다. 11.23 48 0
2904303 클라우드 엔지니어 희망하는데 [2] 프갤러(118.235) 11.23 33 0
2904298 cursor 대체할만한거 있어? [2] ㅇㅇ(124.48) 11.23 45 0
2904295 개발만한 취미가 없는 것 같음 프갤러(61.73) 11.23 57 0
2904294 살면서 잘 한 일... 후배한테 노트북 키스킨 딱 맞는 카라스스킨 5천원 넥도리아(220.74) 11.23 14 0
2904291 에구궁.. 나님 일욜밤까지 모임하구와서 배불러양 [2] ♥냥덩이의우웅한하룽♥갤로그로 이동합니다. 11.23 51 0
2904289 웹디자인은 이미 AI때문에 망한듯 [1] 프갤러(220.70) 11.23 46 0
2904285 왜 극좌들은 하나같이 왕따 당하는걸까? [4] ♥냥덩이의우웅한하룽♥갤로그로 이동합니다. 11.23 44 0
2904266 인공지능 댓글 검사기 발명도둑잡기(118.216) 11.23 27 0
2904265 배달기사 레전드네 진짜; [7] 루도그담당(58.233) 11.23 73 0
2904264 [긴급속보] 한국 연구진이 노벨상 근거를 뒤집자 현재 난리난 천문학계 발명도둑잡기(118.216) 11.23 28 0
2904262 왕따재명 안쓰럽네 ㅠ ㅅ ㅠ [2] ♥냥덩이의우웅한하룽♥갤로그로 이동합니다. 11.23 45 1
2904261 소프트웨어 이름으로 이렁 거 어때? [4] 나르시갤로그로 이동합니다. 11.23 54 0
2904259 긴sql도 셸스크립트도 보기 싫은데 [10] 슈퍼막코더(116.64) 11.23 65 0
2904256 이거 이직 중인데 두개중 어디가야하노 [2] 프갤러(58.231) 11.23 40 0
2904255 베린이평가좀 [1] ㅇㅇ(39.7) 11.23 43 0
2904247 간철수도 어셈블리어한다는데 [2] 타이밍뒷.통수한방(1.213) 11.23 61 0
2904245 국비조언좀요 [2] 프갤러(220.86) 11.23 57 0
2904244 어셈 짜는 중인데 헷갈린다 이기 [12] 루도그담당(58.233) 11.23 89 0
2904243 폴리글랏 툴체인이 나오면 프갤에 평화가 오려나? [10] chironpractor갤로그로 이동합니다. 11.23 65 0
2904242 베이스 ㅍㅌㅊ? ㅇㅇ(203.232) 11.23 42 0
2904240 나 불렀서? ㅇㅅㅇ [6] 프갤러(49.165) 11.23 63 0
2904237 탑 클라스 명문대 진학 퍼펙트 합격 가이드!T 프갤러(121.142) 11.23 42 1
2904232 ❤✨☀⭐⚡☘⛩☃나님 시작합니당☃⛩☘⚡⭐☀✨❤ [3] ♥냥덩이의우웅한하룽♥갤로그로 이동합니다. 11.23 62 0
2904231 이제 러스트 빠돌이 프갤에 안 오겠군 ㅋㅋ [1] 나르시갤로그로 이동합니다. 11.23 46 0
2904230 언어 선택권도 수저순일텐데 [2] chironpractor갤로그로 이동합니다. 11.23 61 0
2904229 파이선 얼마나 개떡 같은데 ㅎㅎ [10] 나르시갤로그로 이동합니다. 11.23 67 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2