[완료]while문을 썼는데 뭔가 이상하네요..(뒤에 내용이 더 있는데 읽지 않고 파일종료..)

mtg1의 이미지

뭐랄까, 제목이 좀 이상한데요..

void QS(int num[], int d){//퀵소트입니다.
	int left,right;
 
	int key;
	if (d <= 1) return;// 구간이 1이면 정렬 끝
 
	key=num[d-1];
 
	for (left=0,right=d-2;;left++,right--) {
		while (num[left] < key) { left++; }
		while (num[right] > key) { right--; }
		if (left >= right) break;            // 좌우가 만나면 끝
		SWAP(num[left],num[right]);
	}
	SWAP(num[left],num[z-1]);                   // 기준값과 i위치의 값 교환
    QS(num,left);                           // 왼쪽 구간 정렬
	QS(num+left+1,z-left-1);        // 오른쪽 구간 정렬. 이 둘을 삽입정렬로 교환...하면 2_2 끝!!!!
}
void bufin1(int a, int b, int c, int d){	
	a=0;
	while(a<=255&&b<z){
		in1[a]=number[b];
		a++;
		b++;
		if(a==256){
			d=a;
			a=0;
			b=b+(2*MAXN);
 
		}
		if(b>=z){
			d=a;
			c=1;
			a=0;
 
		}
 
	}
	QS(in1, d);
}
 
while(1){
		a5=0;
		b5=0;
		c5=0;
		printf("!!!!");
		bufin1(a1,a2, a3, a4);
		printf("@@@@");
		bufin2(b1,b2, b3, b4);

위에서 결과를 보면 !!!!까지 출력이 되고 bufin1 함수까지 실행이 됩니다;

그 뒤에 bufin2(구조는 bufin1과 비슷합니다)를 읽지 않고 종료가 되버리네요;

뭐가 문제인걸까요..ㄷㄷ; 일단 bufin1은 정상적인 결과가 나오긴 했습니다;

obbaya의 이미지

printf 안에 \n 넣어보세요.

보이는 게 전부가 아닐 것 같은 느낌이...

mirr187의 이미지

얘기하시는 바와 같이 자신이 원하는 바와 다를 경우에 할 수 있는 최선의 방법은 디버깅이죠..;;

디버깅 툴을 사용하시거나.. 여의치 않으시다면.. 해당 변수가 넘어와서 어떤식으로 처리되는지 변수의 값을 출력해서 추적하실 수 밖에 없습니다..

보여주시는 내용만 가지고는 어떤 변수가 들어와서 어떤식으로 처리되는지 정확하게 알려드릴수가 없거든요

위의 코드만 봐서는 뭐라고 조언하기 참 힘들군요...

mtg1의 이미지

비쥬얼 스튜디오 6.0을 이용합니다.(;;)

디버그로 실행을 해보니 이런 오류메세지가 뜨네요;

Unhandled exception in @@.ex: 0xC000000FD: Stack Overflow.

unhandled exception in @@@.exe: 0xcoooooo5: Access Violation.

...무슨 의미죠..?-ㅅ-??

goahno의 이미지

left는 어떻게든 key값과 같은 값이 나올 수는 있을 것 같은데
right는 배열의 범위를 벗어날 수도 있을 것 같네요.

mtg1의 이미지

확실히...지금 천천히 보니까 그렇네요...;

일단 직접 수정 시도해보겠습니다...만,

잘 않되면 다시 질문 올릴께요;;

도움 감사합니다!

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.