数组去重函数,只用stdio.h
时间: 2024-09-26 10:12:00 浏览: 40
数组去重函数通常涉及到遍历数组并检查元素是否已存在其他位置。由于`stdio.h`主要是输入输出库,并不直接提供数组处理的功能,我们通常会使用标准库`stdlib.h`和`stdbool.h`来辅助实现。下面是一个简单的示例,假设我们有一个整数数组:
```c
#include <stdio.h>
#include <stdbool.h>
bool isDuplicate(int arr[], int size) {
for (int i = 0; i < size - 1; i++) {
for (int j = i + 1; j < size; j++) {
if (arr[i] == arr[j])
return true;
}
}
return false;
}
void removeDuplicates(int arr[], int n) {
bool duplicateExists = isDuplicate(arr, n);
if (!duplicateExists)
return;
int uniqueArr[n];
int uniqueIndex = 0;
for (int i = 0; i < n; i++) {
if (!isDuplicate(uniqueArr, uniqueIndex)) {
uniqueArr[uniqueIndex++] = arr[i];
}
}
// 如果有重复,调整原始数组大小并复制非重复元素
for (int i = uniqueIndex; i < n; i++)
arr[i] = arr[uniqueIndex++];
printf("去重后的数组:\n");
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
}
int main() {
int arr[] = {1, 2, 2, 3, 4, 5, 5, 6};
int n = sizeof(arr) / sizeof(arr[0]);
removeDuplicates(arr, n);
return 0;
}
```
在这个例子中,`isDuplicate()`函数用于检测是否有重复元素,`removeDuplicates()`函数则创建一个新的去重数组。注意这个方法并不节省原始数组的空间,如果内存有限,可以考虑使用其他数据结构如链表。
阅读全文
相关推荐
data:image/s3,"s3://crabby-images/5402c/5402c08311ac4060fea3813aa755d24bfad9113e" alt="h"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/48ecf/48ecfff65b0229a65d66a94d53c67b4ec0248998" alt="docx"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="-"
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="rar"