for문에서 중복 않된 배열값만 얻고자 할때 어떻게 하나요?
글쓴이: kimyh / 작성시간: 토, 2003/10/25 - 10:20오전
어제 php school에 질문을 올렸는데 아직 답이없어서 다시 올립니다.
도와 주세요.
아래 소스에서 배열값 $aaa[0],$aaa[1],$aaa[2],$aaa[3],$aaa[4],....를 얻고자 할때
for문이 돌때 나오는 배열값을 이전에 나왔던 모든값들과 비교하여 같은값이면 버리고 중복되지 않은값만 취하고자 하는데
이전에 나왔던 모든값들과 비교하는 구문을 만들지 못하겠군요.
즉 for문이 돌때마다 나오는 새로운 값만 취하고자 합니다.
mysql_connect("$dbHost","$dbUser","$dbPass"); $queryString = "SELECT * FROM $table; $result = mysql($dbName,$queryString); for($i=0; $i<=$total-1; $i++) { $row = mysql_fetch_array($result); $array[$i]['abc'] = $row['abc']; $aaa[$i] = $array[$i][abc]; echo "$aaa[0] $aaa[1] $aaa[2],$aaa[3]........"; }
그리고 이전의 모든값들과 비교하는 구문이 있다면 어느곳에 삽입을 해야 할까요>
선배님들의 고견을 듣고 싶습니다.
Forums:
Re: for문에서 중복 않된 배열값만 얻고자 할때 어떻게 하나요?
이런류는 데이터검색수가 늘어남에따라 처리사간은 제곱으로 늘어나겠네요.
2중for 문을 써야겠네요..
C 로 표현해보면....
$aaa[$i] 가 NULL 로 초기화 되어 시작했을때..
<=들어갈부분.ㅡ,.ㅡ;
이란곳에 들어가면 되겠네요..
for( i=0; $aaa[$i] != NULL; i++)
if( strcmp( $aaa[$i] , $row['abc'] ) == 0 )break;
if( $aaa[$i] != NULL )continue;
----------------------------------------------------------------------------
출력되는 값의 순서가 이전 배열의 저장 순서와 일치해야 합니까?만
출력되는 값의 순서가 이전 배열의 저장 순서와 일치해야 합니까?
만약 아니라면, 원래 배열을 소트하시고 unique (php에도 있겠죠?) 계열을 한번 호출하시면 될 것 같습니다만...
그럼, 이만...
두분 답변 감사합니다.중복된 필드값에서 서로 다른 배열값만 취하고자
두분 답변 감사합니다.
중복된 필드값에서 서로 다른 배열값만 취하고자 하는건데 출력순서는 상관없이 서로 다른 배열값만 나오면됩니다.
소스는 php 소스입니다.
그리고 unique 함수를 제가 잘 모르는데 unique 필드의 key값을 별도로
지정을 해야하는건가요.
그런데 필드 abc는 서로 중복된 내용들이 많이 저장이 되는 필드거든요.
오늘이 4일째 헤매고 있습니다,
도와 주세요.
살며 그리고 사랑하며...
정보는 공유할때 그 가치가 있는것.....
나의 조그만 지식공유는 남에게 엄청난 기쁨을 안겨 준다.
[code:1]for i = 0 to (number - 1)
간략히 작성한 pseudo-code입니다.
맞는지 확인은 안해봤지만 대강 맞을것 같고요.
응용해서 쓰시면 되겠습니다.
데이터 수를 n이라고 할 때 대략 O(n^2)의 notation을 가지고요.
( 몇번 중복될지 모르기 때문에 정확하진 않겠죠. )
해보진 않았지만, Heap을 만들면 O(n log n)에도 될 것 같은데,
n이 크지 않으면 이정도로 충분할 것 같네요.
DISTINCT 로 해결 안되는 문제인가요?
예제를 보아하니 DB결과를 중복값 제거하고 보여주려는 의도 같은데...
DISTINCT로 쿼리하면 안되는 문제인가요? : )
Overgrown Schoolboy -
(좋은) hash를 쓰면 O(n) 시간에 중복 검사를 할 수 있죠.
(좋은) hash를 쓰면 O(n) 시간에 중복 검사를 할 수 있죠.
댓글 달기