Студопедия

КАТЕГОРИИ:


Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748)

Использование датчика случайных чисел для формирования массива




 

Простейший ДСЧ работает следующим образом:

1) Берется большое число К и произвольное x0 [0,1].

2) Формируются числа х1 =дробная_часть(х0);

х2 =дробная_часть (х1); и т.д.

В результате получается последовательность чисел х0, х1, х2,... беспорядочно разбросанных по отрезку от 0 до 1. Их можно считать случайными, а точнее псевдослучайными. Реальные ДСЧ реализуют более сложную функцию f(x).

В C++ имеется специальная функция

int rand() – возвращает псевдослучайное число из диапазона 0... RAND_MAX=32767, описание функции находится в файле <stdlib.h>.

 

Пример 47. Формирования и печати массива с помощью ДСЧ:

#include "stdafx.h"

#include<iostream>

#include<stdlib.h>

#include <conio.h> // файл, где определена функция getch()

using namespace std;

void main()

{

int a[100];

int n;

cout<<"\nEnter the size of array:";

cin>>n;

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

{

a[I]=rand()%100-50;

cout<<a[I]<<" ";

}

getch(); // ждать нажатия любой клавиши

}

 

В этой программе используется перебор массива по одному элементу слева направо с шагом 1.

 

Пример 33. Найти максимальный элемент массива.

void main()

{

int a[100];

int n;

cout<<”\nEnter the size of array:”;cin>>n;

for(int I=0; I<n; I++) //ввод массива

{a[I]=rand()%100-50;

cout<<a[I]<<” “;

}

int max=a[0];

for(I=1;I<n;I++)

if (a[I]>max) max=a[I];

cout<<”\nMax=”<<max”;

}

В этой программе также используется перебор массива по одному элементу слева направо с шагом 1.

 

Пример 34. Найти сумму элементов массива с четными индексами.

void main()

{

int a[100];

int n;

cout<<”\nEnter the size of array:”;

cin>>n;

for(int I=0;I<n;I++) //ввод массива

{a[I]=rand()%100-50;

cout<<a[I]<<” “;

}

int Sum=0;

for(I=0;I<n;I+=2)

Sum+=a[I]; //элементы с индексами 0, 2, 4…

cout<<”\nSum=”<<Sum;

}

//Второй способ

for (I=0;I<n;I++)

if(I%2==0) Sum+=a[I]; //элементы с индексами 0, 2, 4…

cout<<”\nSum=”<<Sum ”;




Поделиться с друзьями:


Дата добавления: 2014-11-29; Просмотров: 765; Нарушение авторских прав?; Мы поможем в написании вашей работы!


Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет



studopedia.su - Студопедия (2013 - 2024) год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! Последнее добавление




Генерация страницы за: 0.176 сек.