Turbo-C
C++Builder  |  Delphi  |  FireMonkey  |  C/C++  |  Free Pascal  |  Firebird
볼랜드포럼 BorlandForum
 경고! 게시물 작성자의 사전 허락없는 메일주소 추출행위 절대 금지
터보-C 포럼
Q & A
FAQ
팁&트릭
강좌/문서
자료실
Lua 게시판
볼랜드포럼 홈
헤드라인 뉴스
IT 뉴스
공지사항
자유게시판
해피 브레이크
공동 프로젝트
구인/구직
회원 장터
건의사항
운영진 게시판
회원 메뉴
북마크
볼랜드포럼 광고 모집

C/C++ Q/A
[1339] mergesort 인데 도무지 재귀함수때문에 이해가 안가내여 .. 잘 풀어서 설명좀 해주셨으면 ^^
성일 [] 1383 읽음    2002-10-13 02:34

template<class ItemType>
inline void Swap(ItemType& item1, ItemType& item2)

{
    ItemType tempItem;
    tempItem = item1;
    item1 = item2;
    item2 = tempItem;
}


const int MAX_ITEMS = 20;

template<class ItemType>
void Merge(ItemType values[], int leftFirst, int leftLast,
       int rightFirst, int rightLast)

{
  ItemType tempArray[MAX_ITEMS];
  int index = leftFirst;
  int saveFirst = leftFirst;
  while ((leftFirst <= leftLast) && (rightFirst <= rightLast))
  {
    if (values[leftFirst] < values[rightFirst])
    {
      tempArray[index] = values[leftFirst];
      leftFirst++;
    }
    else
    {
      tempArray[index] = values[rightFirst];
      rightFirst++;
    }
    index++;
  }
  while (leftFirst <= leftLast)

  {
    tempArray[index] = values[leftFirst];
    leftFirst++;
    index++;
  }
  while (rightFirst <= rightLast)
  {
    tempArray[index] = values[rightFirst];
    rightFirst++;
    index++;
  }
  for (index = saveFirst; index <= rightLast; index++)
    values[index] = tempArray[index];
}

template<class ItemType>
void MergeSort(ItemType values[], int first, int last)
{
  if ( first < last)
  {
    int middle = (first + last) / 2;
    MergeSort(values, first, middle);
    MergeSort(values, middle + 1, last);
    Merge(values, first, middle, middle + 1, last);
  }
}



저것이 mergesort 구여... 구체적인 숫자들을 예로들어 설명 해주셨으면 좋겠음다
저기 재귀함수 보이시져 저것 때문에 골치아퍼요..
저렇게 짜는것이 호율적인건가여 아닌가여 ...
설명부탁함다  꾸벅 (--)(__)

+ -

관련 글 리스트
1339 mergesort 인데 도무지 재귀함수때문에 이해가 안가내여 .. 잘 풀어서 설명좀 해주셨으면 ^^ 성일 1383 2002/10/13
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.