antoncezame
16.10.2021 02:26

Крайний : )

заполните массив из n элементов случайными числами в интервале от 1 до n так, чтобы в массив обязательно вошли все числа от 1 до n. (постройте случайную перестановку).

язык программирования с++.

Нажмите на рекламу ниже и сразу увидите ответ
Популярные вопросы:
Ответ:
KennyPro
10.10.2020 13:31

#include <iostream>

using namespace std;

void swap(int i, int j, int a[])

{

   int t = a[i];

   a[i] = a[j];

   a[j] = t;

}

int main()

{

   int n, s1 = 0, s2 = 0, n1 = 0, n2 = 0;

   cin >> n;

   int a[n];

   srand(time(0)); // инициализируем датчик

   // заполняем массив подряд от 1 до n

   for(int i=0; i<n; i++)

       a[i] = i + 1;

   int np = min(rand() % n, 5); // случайное количество перестановок

   for(int i=1; i<=np; i++)

       swap(rand()%(n), rand()%(n), a);

   for(int i=0; i<n; i++)

       cout << a[i] << " ";

   return 0;

}

0,0(0 оценок)
Полный доступ
Позволит учиться лучше и быстрее. Неограниченный доступ к базе и ответам от экспертов и ai-bota Оформи подписку
logo
Начни делиться знаниями
Вход Регистрация
Что ты хочешь узнать?
Спроси ai-бота