Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.67/12: Рейтинг темы: голосов - 12, средняя оценка - 4.67
desperateX
0 / 0 / 0
Регистрация: 28.11.2012
Сообщений: 15
1

Как рандомно заполнить одномерный массив единицами и нулями?

03.03.2013, 19:55. Просмотров 2273. Ответов 8
Метки нет (Все метки)

как рандомно заполнить одномерный массив единицами и нулями???
0
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.03.2013, 19:55
Ответы с готовыми решениями:

Заполнить двумерный массив размером n*n единицами и нулями как на шахматной доске
Заполнить двумерный массив размером n*n единицами и нулями таким образом, чтобы...

Заполнить двумерный массив единицами и нулями в определенной последовательности
ребят, помогите, в голову никак не укладывается, нужно заполнить двумерный...

Заполнить двумерный массив нулями и единицами в шахматном порядке
Помогите пожалуйста с задачими га языке с++ Заполнить двумерный массив...

Заполнить двумерный массив размером n Х n единицами и нулями в шахматном порядке
4) Заполнить двумерный массив размером n Х n единицами и нулями таким образом,...

Целочисленный массив заполнить нулями и единицами, расположив их в шахматном порядке
3. Целочисленный массив К(m,n) заполнить нулями и единицами, расположив их в...

8
Pepsy
47 / 32 / 9
Регистрация: 05.01.2013
Сообщений: 307
03.03.2013, 20:01 2
C++
1
2
3
4
5
6
7
8
9
10
11
#include <time.h>
using namespace std;
void main()
{
int massiv[b];
srand(time(NULL));
for(int i=0, i<=b, i++)
{
massiv[i]=random()%1;
}
}
b - количество елементов
1
d3n1sk4
3 / 3 / 1
Регистрация: 11.11.2012
Сообщений: 29
03.03.2013, 20:01 3
Лучший ответ Сообщение было отмечено как решение

Решение

C++
1
2
3
srand(time(0));
for (int i = 0;i < lenght;i++)
        a[i] = (rand() % 2);
Я новичок, если что исправьте
3
Croessmah
++Ͻ
14777 / 8453 / 1605
Регистрация: 27.09.2012
Сообщений: 20,802
Записей в блоге: 2
Завершенные тесты: 1
03.03.2013, 20:11 4
Цитата Сообщение от Pepsy Посмотреть сообщение
C++
1
random()%1;
чему Вы думаете равен остаток от деления любого числа на 1?
1
desperateX
0 / 0 / 0
Регистрация: 28.11.2012
Сообщений: 15
03.03.2013, 20:17  [ТС] 5
for(int i=0, i<=b, i++)
разве здесь не должно быть i<b????
0
Croessmah
++Ͻ
14777 / 8453 / 1605
Регистрация: 27.09.2012
Сообщений: 20,802
Записей в блоге: 2
Завершенные тесты: 1
03.03.2013, 20:26 6
Цитата Сообщение от desperateX Посмотреть сообщение
разве здесь не должно быть i<b????
должно. Код из поста #2 даже не скомпилируется
1
palva
3116 / 2246 / 452
Регистрация: 08.06.2007
Сообщений: 8,168
Записей в блоге: 4
03.03.2013, 20:42 7
Цитата Сообщение от d3n1sk4 Посмотреть сообщение
a[i] = (rand() % 2);
Это плохой вариант. Линейный конгруэнтный метод, насколько я понимаю, вообще дает чередование последнего бита. Правда, когда я сейчас пробовал в VS 2008, то там чередования не увидел, значит там генерируется как-то по-другому.
Как бы то ни было в книгах даются рекомендации использовать старшие биты, которые имеют лучшее статистическое качество. Например:
C++
1
2
a[i] = rand()*2>RAND_MAX?1:0; // или
a[i] = rand()>>14;
Второй вариант, работает, если точно известно, что RAND_MAX==0x7fff.
1
d3n1sk4
3 / 3 / 1
Регистрация: 11.11.2012
Сообщений: 29
03.03.2013, 21:09 8
Цитата Сообщение от palva Посмотреть сообщение
Это плохой вариант. Линейный конгруэнтный метод, насколько я понимаю, вообще дает чередование последнего бита. Правда, когда я сейчас пробовал в VS 2008, то там чередования не увидел, значит там генерируется как-то по-другому.
Сейчас попробовал в VS 2010 чередования нет
0
palva
3116 / 2246 / 452
Регистрация: 08.06.2007
Сообщений: 8,168
Записей в блоге: 4
03.03.2013, 22:17 9
Помотрел в Википедии про линейный конгруэнтный метод. Оказывается в rand выдаются только старшие биты числа. Вот какие данные приводятся о датчике GNU Compiler Collection. Внутренняя 32-разрядная переменная X вычисляется по формуле
http://www.cyberforum.ru/cgi-bin/latex.cgi?X_{k+1}=(aX_k+c) \mbox{ mod }m, в которой берется http://www.cyberforum.ru/cgi-bin/latex.cgi?m=2^{32},\quad a=69069,\quad c=5, выдаваемые биты результата в rand() - биты 30..16.

Так что младшие биты должны иметь приемлемое качество.

Добавлено через 29 минут
О том, что младшие разряды линейного конгруэнтного метода имеют небольшую периодичность есть у Кнута во втором томе на самых первых страницах. Конечно, он говорит о разрядах числа X, а не о тех разрядах, которые вырезаются из числа X функцией rand.
0
03.03.2013, 22:17
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.03.2013, 22:17

Целочисленный массив заполнить нулями и единицами, расположив их в шахматном порядке
Целочисленный массив K(n,n) заполнить нулями и единицами, расположив их в...

Заполнить массив заданного размера нулями и единицами по указанному принципу
Ребят дали задачу не пойму как ее решить, Заполнить массив из 100 элементов...

Целочисленный массив a(n, n) заполнить нулями и единицами, расположив их в шахматном порядке.
Помогите найти ошибку в программе!!! При запуске все работает, но зависает с...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru