将存储循环结果传输到另一个阵列

时间:2014-02-06 17:40:32

标签: c arrays sorting loops

所以这是一个从最小值到最大值对数组进行排序的循环,我需要将此循环的结果放入另一个数组中,这样我就可以过滤并删除仅出现一次的数字并找到剩下的最后一个成员。

这是我到目前为止的代码:

#include<stdio.h>
#include<conio.h>
#define buffas 1024
void main() {
    int arr[buffas],i,j,element,no,temp;

    printf("\nEnter the no of Elements: ");
    scanf("%d", &no);
    for(i=0; i<no; i++) {
        printf("\n Enter Element %d: ", i+1);
        scanf("%d",&arr[i]);
    }
    for(i=0; i<no; i++) {
        for(j=i; j<no; j++) {
            if(arr[i] > arr[j]) {
                temp=arr[i];
                arr[i]=arr[j];
                arr[j]=temp;
            }
        }
    }
    printf("\nSorted array:");

    for(i=0; i<no; i++) {
        printf("\t%d",arr[i]);
    }

    getch();
}

如何更改   

printf("\t%d",arr[i]);  

要填充另一个数组,然后对其进行排序以删除单个条目,并留下至少重复一次的那些数据 例如。第一个aray是

  

2 2 1 6 9 9

在第二次排序后,结果应为

  

2 2 9 9

1 个答案:

答案 0 :(得分:0)

#include <stdio.h>

#define buffas 16

int main(void)
{
  /* Instead of original input and sorting code */
  int arr[] = { 1, 2, 2, 6, 9, 9, 10, 10, 10, 11, 12, 13, 14 };
  int no = sizeof(arr) / sizeof(arr[0]);

  /* Code to copy only duplicated elements in arr */
  int copy[buffas];
  int n = 0;
  for (int i = 0; i < no; i++)
  {
    int j;
    for (j = i + 1; j < no; j++)
    {
      if (arr[i] != arr[j])
        break;
    }
    if (j - i > 1)
    {
      for (int k = i; k < j; k++)
        copy[n++] = arr[k];
      i = j - 1;
    }
  }

  /* Print results for verification */
  for (int i = 0; i < n; i++)
    printf("c[%d] = %d\n", i, copy[i]);
  return 0;
}

代码已经运行了不同长度的排序数组和数组中的不同数据;这似乎是正确的。上面的代码产生输出:

c[0] = 2
c[1] = 2
c[2] = 9
c[3] = 9
c[4] = 10
c[5] = 10
c[6] = 10

请注意,代码使用C99功能在for循环控制语句中声明变量;如果您使用的是Windows且没有C99支持,则需要在循环外声明ik。如果您正在使用GCC,则需要添加-std=c99或类似选项。