鱼C论坛

 找回密码
 立即注册
查看: 1867|回复: 1

C语言数组

[复制链接]
发表于 2023-11-8 17:30:06 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
定义一维数组,存储N个整型数据,输入实际处理元素的个数n(n<=N),产生n个随机数(随机数小于100)存入数组并显示。完成如下功能:

(1)求出所有高于平均数的数据。

(2)交换最大数和最小数的位置。

(3)对这组数据进行逆置。

(4)对这组数据进行排序(递增)并显示。

(5)从键盘输入一个数,查找数组中是否存在,并显示其下标。

     对排序前(无序)数据采用顺序查找,显示依次比较的数据、比较次数以及查找结果。

     对排序后数据采用二分查找,显示依次比较的数据、比较次数以及查找结果。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-11-8 17:34:00 | 显示全部楼层
下面是实现该功能的C语言代码:

  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. void generateRandomNumbers(int arr[], int n) {
  4.     for (int i = 0; i < n; i++) {
  5.         arr[ i] = rand() % 100;
  6.     }
  7. }

  8. void displayArray(int arr[], int n) {
  9.     for (int i = 0; i < n; i++) {
  10.         printf("%d ", arr[ i]);
  11.     }
  12.     printf("\n");
  13. }

  14. void findAboveAverage(int arr[], int n) {
  15.     int sum = 0;
  16.     for (int i = 0; i < n; i++) {
  17.         sum += arr[ i];
  18.     }
  19.     double average = (double)sum / n;

  20.     printf("高于平均数的数据:");
  21.     for (int i = 0; i < n; i++) {
  22.         if (arr[ i] > average) {
  23.             printf("%d ", arr[ i]);
  24.         }
  25.     }
  26.     printf("\n");
  27. }

  28. void swap(int *a, int *b) {
  29.     int temp = *a;
  30.     *a = *b;
  31.     *b = temp;
  32. }

  33. void swapMinMax(int arr[], int n) {
  34.     int minIndex = 0;
  35.     int maxIndex = 0;

  36.     for (int i = 1; i < n; i++) {
  37.         if (arr[ i] < arr[minIndex]) {
  38.             minIndex = i;
  39.         }
  40.         if (arr[ i] > arr[maxIndex]) {
  41.             maxIndex = i;
  42.         }
  43.     }

  44.     swap(&arr[minIndex], &arr[maxIndex]);
  45. }

  46. void reverseArray(int arr[], int n) {
  47.     int start = 0;
  48.     int end = n - 1;

  49.     while (start < end) {
  50.         swap(&arr[start], &arr[end]);
  51.         start++;
  52.         end--;
  53.     }
  54. }

  55. void bubbleSort(int arr[], int n) {
  56.     for (int i = 0; i < n - 1; i++) {
  57.         for (int j = 0; j < n - i - 1; j++) {
  58.             if (arr[j] > arr[j + 1]) {
  59.                 swap(&arr[j], &arr[j + 1]);
  60.             }
  61.         }
  62.     }
  63. }

  64. int sequentialSearch(int arr[], int n, int key) {
  65.     for (int i = 0; i < n; i++) {
  66.         if (arr[ i] == key) {
  67.             return i;
  68.         }
  69.     }
  70.     return -1;
  71. }

  72. int binarySearch(int arr[], int n, int key) {
  73.     int low = 0;
  74.     int high = n - 1;

  75.     while (low <= high) {
  76.         int mid = (low + high) / 2;
  77.         if (arr[mid] == key) {
  78.             return mid;
  79.         }
  80.         else if (arr[mid] < key) {
  81.             low = mid + 1;
  82.         }
  83.         else {
  84.             high = mid - 1;
  85.         }
  86.     }
  87.     return -1;
  88. }

  89. int main() {
  90.     int N;
  91.     printf("请输入数组的大小N:");
  92.     scanf("%d", &N);

  93.     int arr[N];
  94.     int n;

  95.     printf("请输入实际处理元素的个数n:");
  96.     scanf("%d", &n);

  97.     generateRandomNumbers(arr, n);

  98.     printf("随机生成的数组:");
  99.     displayArray(arr, n);

  100.     findAboveAverage(arr, n);

  101.     swapMinMax(arr, n);
  102.     printf("交换最大数和最小数的位置后的数组:");
  103.     displayArray(arr, n);

  104.     reverseArray(arr, n);
  105.     printf("逆置后的数组:");
  106.     displayArray(arr, n);

  107.     bubbleSort(arr, n);
  108.     printf("排序后的数组:");
  109.     displayArray(arr, n);

  110.     int key;
  111.     printf("请输入要查找的数:");
  112.     scanf("%d", &key);

  113.     int index = sequentialSearch(arr, n, key);
  114.     if (index != -1) {
  115.         printf("顺序查找:找到了,下标为%d\n", index);
  116.     }
  117.     else {
  118.         printf("顺序查找:未找到\n");
  119.     }

  120.     index = binarySearch(arr, n, key);
  121.     if (index != -1) {
  122.         printf("二分查找:找到了,下标为%d\n", index);
  123.     }
  124.     else {
  125.         printf("二分查找:未找到\n");
  126.     }

  127.     return 0;
  128. }
复制代码


这段代码首先定义了一些函数来实现所需的功能,然后在主函数中按照题目要求调用这些函数。具体实现如下:

1.  generateRandomNumbers 函数用于生成n个随机数,并存入数组中。
2.  displayArray 函数用于显示数组中的元素。
3.  findAboveAverage 函数首先计算数组中所有元素的平均值,然后找出高于平均值的数据并显示出来。
4.  swap 函数用于交换两个数的值。
5.  swapMinMax 函数找出数组中的最小数和最大数的位置,并交换它们的位置。
6.  reverseArray 函数用于将数组逆置。
7.  bubbleSort 函数用冒泡排序算法对数组进行递增排序。
8.  sequentialSearch 函数用顺序查找算法在排序前的数组中查找给定的数,并返回其下标。
9.  binarySearch 函数用二分查找算法在排序后的数组中查找给定的数,并返回其下标。
10. 主函数中首先读取数组的大小N和实际处理元素的个数n,然后生成随机数组,依次调用各个函数实现题目要求,并显示结果。

注意:为了使用 rand 函数生成随机数,需要包含 stdlib.h 头文件。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-9 09:33

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表