Упражнения C: переставьте массив в таком порядке, чтобы он был наименьшим, самым большим, вторым самым маленьким, вторым по величине и
C Массив: упражнение-102 с решением
Напишите программу на C, чтобы переставить массив в таком порядке: наименьший, наибольший, 2-й наименьший, 2-й наибольший и т. Д.
Пример решения:
Код C:
#include<stdio.h>
void sort(int arr1[], int n)
{
int i, j,temp;
for (i = 0; i < n-1; i++)
{
for (j = 0; j < n-i-1; j++)
{
if (arr1[j] > arr1[j+1])
{
temp = arr1[j];
arr1[j] = arr1[j+1];
arr1[j+1] = temp;
}
}
}
return ;
}
void rearrangeArray(int arr1[], int n)
{
sort(arr1, n);
int tempArr[n];
int ArrIndex = 0;
for (int i = 0, j = n-1; i <= n / 2 || j > n / 2; i++, j--)
{
tempArr[ArrIndex] = arr1[i];
ArrIndex++;
tempArr[ArrIndex] = arr1[j];
ArrIndex++;
}
for (int i = 0; i < n; i++)
{arr1[i] = tempArr[i];}
}
int main()
{
int arr1[] = { 5, 8, 1, 4, 2, 9, 3, 7, 6 };
int n = sizeof(arr1) / sizeof(arr1[0]);
int i = 0;
//------------- print original array ------------------
printf("The given array is: \n");
for(i = 0; i < n; i++)
{
printf("%d ", arr1[i]);
}
printf("\n");
//-----------------------------------------------------------
printf("The new array is: \n");
rearrangeArray(arr1, n);
for (int i = 0; i < n; i++)
printf("%d ",arr1[i]);
return 0;
}
Пример вывода:
Данный массив: 5 8 1 4 2 9 3 7 6 Новый массив: 1 9 2 8 3 7 4 6 5
Блок - схема:
Редактор кода программирования C:
Улучшите этот пример решения и опубликуйте свой код через Disqus.
Previous: написать программу на C для перестановки массива так, чтобы arr [i] = i.
Далее: написать программу на C для обновления каждого элемента массива с умножением предыдущего и следующего чисел в массиве.
Новый контент: Composer: менеджер зависимостей для PHP , R программирования
disqus2code