Переместить в конец массива все его положительные элементы - C (СИ)

Узнай цену своей работы

Формулировка задачи:

Задание

изменить исходный массив следующим образом: переместить в конец массива все его положительные элементы. Порядок следования не перемещаемых элементов не изменять. Вывести на дисплей количество перемещенных элементов. Подскажите как написать прогу

Решение задачи: «Переместить в конец массива все его положительные элементы»

textual
Листинг программы
int ar_swap(double* ar,int n)
{
    int c=0;//счетчик перемешений
    for(int i=0;i<n;i++)
    {
        while(ar[i]>0 && i<n)
        {
            swap(ar[i],ar[n-1]);
            n--;
            c++;
        }
    }
    return c;
}

Объяснение кода листинга программы

  1. Входные данные:
    • double* ar: указатель на начало массива
    • int n: размер массива
  2. Создаем переменную c для подсчета количества выполненных операций обмена
  3. Проходим по всем элементам массива с помощью цикла for от i=0 до n-1
  4. Внутри цикла используем вложенный цикл while для проверки условия ar[i] > 0, если условие выполняется, то меняем местами текущий элемент массива с последним элементом и уменьшаем значение n на 1. Выполняем это до тех пор, пока условие не перестанет выполняться.
  5. После завершения внутреннего цикла увеличиваем значение переменной c на 1.
  6. Возвращаем значение переменной c в качестве результата работы функции.

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

8   голосов , оценка 3.875 из 5
Похожие ответы