КАТЕГОРИИ: Архитектура-(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; Нарушение авторских прав?; Мы поможем в написании вашей работы! Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет |