Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 13, средняя оценка - 5.00
desperateX
0 / 0 / 0
Регистрация: 28.11.2012
Сообщений: 15
#1

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

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

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

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

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

Заполнить двумерный массив единицами и нулями в определенной последовательности - C++
ребят, помогите, в голову никак не укладывается, нужно заполнить двумерный массив Arr значениями "0" и "1" в такой последовательности: 1...

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

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

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

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Pepsy
47 / 32 / 4
Регистрация: 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
Эксперт CЭксперт С++
13214 / 7486 / 842
Регистрация: 27.09.2012
Сообщений: 18,403
Записей в блоге: 3
Завершенные тесты: 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
Эксперт CЭксперт С++
13214 / 7486 / 842
Регистрация: 27.09.2012
Сообщений: 18,403
Записей в блоге: 3
Завершенные тесты: 1
03.03.2013, 20:26 #6
Цитата Сообщение от desperateX Посмотреть сообщение
разве здесь не должно быть i<b????
должно. Код из поста #2 даже не скомпилируется
1
palva
2614 / 1836 / 263
Регистрация: 08.06.2007
Сообщений: 6,994
Записей в блоге: 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
2614 / 1836 / 263
Регистрация: 08.06.2007
Сообщений: 6,994
Записей в блоге: 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
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.03.2013, 22:17
Привет! Вот еще темы с ответами:

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

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

Массив заполнить нулями и единицами, расположив их в шахматном порядке (Прокомментировать код) - C++
#include &lt;iostream&gt; #include &lt;cstdlib&gt; using namespace std; int main() { setlocale(LC_ALL, &quot;&quot;); const int n =...

массив a(n, n) заполнить нулями и единицами, расположив их в шахматном порядке (в чем у меня ошибка?) - C++
Целочисленный массив a(n, n) заполнить нулями и единицами, расположив их в шахматном порядке. #include &lt;stdio.h&gt; #include &lt;conio.h&gt; ...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
03.03.2013, 22:17
Ответ Создать тему
Опции темы

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