所以这是一个从最小值到最大值对数组进行排序的循环,我需要将此循环的结果放入另一个数组中,这样我就可以过滤并删除仅出现一次的数字并找到剩下的最后一个成员。
这是我到目前为止的代码:
#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
答案 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支持,则需要在循环外声明i
和k
。如果您正在使用GCC,则需要添加-std=c99
或类似选项。