В
Все
М
Математика
А
Английский язык
Х
Химия
Э
Экономика
П
Право
И
Информатика
У
Українська мова
Қ
Қазақ тiлi
О
ОБЖ
Н
Немецкий язык
Б
Беларуская мова
У
Українська література
М
Музыка
П
Психология
А
Алгебра
Л
Литература
Б
Биология
М
МХК
О
Окружающий мир
О
Обществознание
И
История
Г
Геометрия
Ф
Французский язык
Ф
Физика
Д
Другие предметы
Р
Русский язык
Г
География
SnegRainbow
SnegRainbow
13.08.2021 02:11 •  Информатика

Крайний : )

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

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

Показать ответ
Ответ:
veterantitanfaoz8ptr
veterantitanfaoz8ptr
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-бота