for문에서 중복 않된 배열값만 얻고자 할때 어떻게 하나요?

kimyh의 이미지

어제 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]........";
}

그리고 이전의 모든값들과 비교하는 구문이 있다면 어느곳에 삽입을 해야 할까요>
선배님들의 고견을 듣고 싶습니다.
ㅡ,.ㅡ;;의 이미지

kimyh wrote:
어제 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]........";
}

그리고 이전의 모든값들과 비교하는 구문이 있다면 어느곳에 삽입을 해야 할까요>
선배님들의 고견을 듣고 싶습니다.

이런류는 데이터검색수가 늘어남에따라 처리사간은 제곱으로 늘어나겠네요.
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;


----------------------------------------------------------------------------

bugiii의 이미지

출력되는 값의 순서가 이전 배열의 저장 순서와 일치해야 합니까?

만약 아니라면, 원래 배열을 소트하시고 unique (php에도 있겠죠?) 계열을 한번 호출하시면 될 것 같습니다만...

그럼, 이만...

kimyh의 이미지

두분 답변 감사합니다.
중복된 필드값에서 서로 다른 배열값만 취하고자 하는건데 출력순서는 상관없이 서로 다른 배열값만 나오면됩니다.

소스는 php 소스입니다.
그리고 unique 함수를 제가 잘 모르는데 unique 필드의 key값을 별도로
지정을 해야하는건가요.

그런데 필드 abc는 서로 중복된 내용들이 많이 저장이 되는 필드거든요.

오늘이 4일째 헤매고 있습니다,
도와 주세요.

살며 그리고 사랑하며...
정보는 공유할때 그 가치가 있는것.....
나의 조그만 지식공유는 남에게 엄청난 기쁨을 안겨 준다.

vacancy의 이미지

for i = 0 to (number - 1)
  do {
    flag = false
    a[i] 가져옴
    for j = 0 to (i - 1)
      if (a[i] == a[j]) {
        flag = true; break;
      }
  } while (flag);

간략히 작성한 pseudo-code입니다.
맞는지 확인은 안해봤지만 대강 맞을것 같고요.
응용해서 쓰시면 되겠습니다.

데이터 수를 n이라고 할 때 대략 O(n^2)의 notation을 가지고요.
( 몇번 중복될지 모르기 때문에 정확하진 않겠죠. )
해보진 않았지만, Heap을 만들면 O(n log n)에도 될 것 같은데,
n이 크지 않으면 이정도로 충분할 것 같네요.

gloridea의 이미지

예제를 보아하니 DB결과를 중복값 제거하고 보여주려는 의도 같은데...

DISTINCT로 쿼리하면 안되는 문제인가요? : )

Overgrown Schoolboy -

cdpark의 이미지

(좋은) hash를 쓰면 O(n) 시간에 중복 검사를 할 수 있죠.

댓글 달기

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
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.