Архитектура Аудит Военная наука Иностранные языки Медицина Металлургия Метрология
Образование Политология Производство Психология Стандартизация Технологии


Лабораторная работа № 6. Программирование с использованием одномерных массивов



Цель лабораторной работы : Изучить способы получения случайных чисел. Написать программу для работы с одномерными массивами.

Работа с массивами

Массив - набор элементов одного и того же типа, объединенных общим именем. Массивы в С# можно использовать по аналогии с тем, как они используются в других языках программирования. Однако С#-массивы имеют существенные отличия: они относятся к ссылочным типам данных, более того - реализованы как объекты. Фактически имя массива является ссылкой на область кучи (динамической памяти), в которой последовательно размещается набор элементов определенного типа. Выделение памяти под элементы происходит на этапе инициализации массива. А за освобождением памяти следит система сборки мусора - неиспользуемые массивы автоматически утилизируются данной системой.

Рассмотрим в данной лабораторной работе одномерные массивы. Одномерный массив - это фиксированное количество элементов одного и того же типа, объединенных общим именем, где каждый элемент имеет свой номер. Нумерация элементов массива в С# начинается с нуля, то есть, если массив состоит из 10 элементов, то его элементы будут иметь следующие номера: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9.

Одномерный массив в С# реализуется как объект, поэтому его создание представляет собой двухступенчатый процесс. Сначала объявляется ссылочная переменная на массив, затем выделяется память под требуемое количество элементов базового типа, и ссылочной переменной присваивается адрес нулевого элемента в массиве. Базовый тип определяет тип данных каждого элемента массива. Количество элементов, которые будут храниться в массиве, определяется размер массива.

В общем случае процесс объявления переменной типа массив, и выделение необходимого объема памяти может быть разделено. Кроме того на этапе объявления массива можно произвести его инициализацию. Поэтому для объявления одномерного массива может использоваться одна из следующих форм записи:

базовый_тип [] имя__массива;

Описана ссылка на одномерный массив, которая в дальнейшем может быть использована для адресации на уже существующий массив. Например: int [] a;

базовый_тип [] имя__массива = new базовый_тип [размер];

Объявлен одномерный массив заданного типа и выделена память под одномерный массив указанной размерности. Адрес данной области памяти записан в ссылочную переменную. Элементы массива равны нулю (В C# элементам массива присваиваются начальные значения по умолчанию в зависимости от базового типа. Для арифметических типов - нули, для ссылочных типов - null, для символов - пробел). Например: int []a=new int [10];

базовый_тип [] имя__массива={список инициализации};

Выделена память под одномерный массив, размерность которого соответствует количеству элементов в списке инициализации. Адрес этой области памяти записан в ссылочную переменную. Значение элементов массива соответствует списку инициализации. Например: int []a={0, 1, 2, 3};

Обращения к элементам массива происходит с помощью индекса, для этого нужно указать имя массива и в квадратных скобках его номер. Например, a[0], b[10], c[i].

Так как массив представляет собой набор элементов, объединенных общим именем, то обработка массива обычно производится в цикле. Например:

int[] myArray = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };

int i;

for (i = 0; i < 10; ++i)

Console.WriteLine(myArray[i]);

Случайные числа

Одним из способов задания массива является задание определение элементов через случайные числа. Для работы со случайными числами используются в основном два метода класса Random: Random и Next. Метод Random подготавливает работу со случайными числами, обеспечивая, надежный способ создания непредсказуемой последовательности чисел.

Метод Random.Next создает случайное число в диапазоне значений от нуля до Int32.MaxValue. Для создания случайного числа в диапазоне от нуля до какого-либо другого положительного числа используется перегрузка метода Random.Next(Int32). Для создания случайного числа в другом диапазоне используется перегрузка метода Random.Next(Int32, Int32).

6.3. Порядок выполнения индивидуального задания

Создайте форму с элементами управления как приведено на рис. 6.1. Опишите одномерный массив. Создайте обработчики события для кнопок (код приведен ниже). Данная программа заменяет все отрицательные числа нулями. Протестируйте правильность выполнения программы. Модифицируйте программу в соответствии с индивидуальным заданием.

Рис. 6.1. Окно программы для работы с одномерными массивами

using System;

using System.Collections.Generic;

using System.ComponentModel;

using System.Data;

using System.Drawing;

using System.Linq;

using System.Text;

using System.Windows.Forms;

 

namespace WindowsFormsApplication1

{

public partial class Form1: Form

{

int[] Mas = new int[15];

 

public Form1()

{

InitializeComponent();

}

 

private void button1_Click(object sender, EventArgs e)

{

Random rand = new Random();

textBox1.Text = " ";

for (int i = 0; i < 15; i++)

{

Mas[i] = rand.Next(-50, 50);

textBox1.Text += " Mas[" + Convert.ToString(i) +" ] = "

+ Convert.ToString(Mas[i]) + Environment.NewLine;

}

 

}

 

private void button2_Click(object sender, EventArgs e)

{

textBox2.Text = " ";

for (int i = 0; i < 15; i++)

{

if (Mas[i] < 0) Mas[i] = 0;

textBox2.Text += " Mas[" + Convert.ToString(i) + " ] = "

+ Convert.ToString(Mas[i]) + Environment.NewLine;

}

 

}

 

}

 

}

Варианты заданий

1) В массиве из 20 целых чисел найти наибольший элемент и поменять его местами с первым элементом.

2) В массиве из 10 целых чисел найти наименьший элемент и поменять его местами с последним элементом.

3) В массиве из 15 вещественных чисел найти наибольший элемент и поменять его местами с последним элементом.

4) В массиве из 25 вещественных чисел найти наименьший элемент и поменять его местами с первым элементом.

5) Дан массив X, содержащий 27 элементов. Вычислить и вывести элементы нового массива Y, где yi =6.85xi2-1.52. Если yi< 0, то вычислить и вывести a=xi3-0.62 и продолжить вычисления; если yi³ 0, то вычислить и вывести b=1/xi2 и продолжить вычисления.

6) Дан массив X, содержащий 16 элементов. Вычислить и вывести значения di, где и значения di> 0.1.

7) Дан массив Y, содержащий 25 элементов. Записать в массив R и вывести значения элементов, вычисляемые по формуле , i=1, 2, …, 25.

8) Дан массив F, содержащий 18 элементов. Вычислить и вывести элементы нового массива pi=0.13fi3-2.5fi+8. Вывести отрицательные элементы массива P.

9) Вычислить и вывести элементы массива Z, где zi=i2+1, если i – нечетное, и zi=2i-1, если i – четное. Сформировать и вывести массив D: di=2.5zi, если zi< 2.5 и di=zi/2.5, если zi³ 2.5.

10) Заданы массивы D и E. Вычислить и вывести значения fi=(2di+sin ei)/di, где i=1, 2, …, 16; вывести 1< fi< 3.

11) В массиве R, содержащем 25 элементов, заменить значения отрицательных элементов квадратами значений, значения положительных увеличить на 7, а нулевые значения оставить без изменения. Вывести массив R.

12) Дан массив A целых чисел, содержащий 30 элементов. Вычислить и вывести сумму тех элементов, которые кратны 5.

13) Дан массив A целых чисел, содержащий 30 элементов. Вычислить и вывести сумму тех элементов, которые нечетны и отрицательны.

14) Дан массив A целых чисел, содержащий 30 элементов. Вычислить и вывести сумму тех элементов, которые удовлетворяют условию |ai|< i2.

15) Дан массив A целых чисел, содержащий 30 элементов. Вычислить и вывести количество и сумму тех элементов, которые делятся на 5 и не делятся на 7.

16) Дан массив A вещественных чисел, содержащий 25 элементов. Вычислить и вывести число отрицательных элементов и число членов, принадлежащих отрезку[1, 2].

17) Дан массив C, содержащий 23 элемента. Вычислить и вывести среднее арифметическое всех значений ci> 3.5.

18) Дан массив Z целых чисел, содержащий 35 элементов. Вычислить и вывести R=S+P, где S – сумма четных элементов, меньших 3, P – произведение нечетных элементов, больших 1.

19) Дан массив Q натуральных чисел, содержащий 20 элементов. Найти и вывести те элементы, которые при делении на 7 дают остаток 1, 2 или 5.

20) Дан массив Q натуральных чисел, содержащий 20 элементов. Найти и вывести те элементы, которые обладают тем свойством, что корни уравнения qi2+3qi-5=0 действительны и положительны.

21) Дан массив, содержащий 10 элементов. Вычислить произведение элементов, стоящих после первого отрицательного элемента. Вывести исходный массив и результат вычислений.

22) Дан массив, содержащий 14 элементов. Вычислить сумму элементов, стоящих до первого отрицательного элемента. Вывести исходный массив и результат вычислений.

23) Дан массив содержащий 12 элементов. Все четные элементы сложить, вывести массив и результат.

24) Дан массив, содержащий 15 элементов. Все положительные элементы возвести в квадрат, а отрицательные умножить на 2. Вывести исходный и полученный массив.

25) Дан массив, содержащий 14 элементов. Все отрицательные элементы заменить на 3. Вывести исходный и полученный массив.


Поделиться:



Популярное:

  1. D триггеры, работающие по фронту.
  2. I. Техники безопасности при подготовительных работах.
  3. II. Работа со словарём. Научитесь одним движением руки открывать нужную букву в словаре.
  4. А - типовые, разработанные в СоюзДорПроекте; б - из стеклофибробетона
  5. Акушерство: работа с младенцами и детьми
  6. Антимонопольная политика проводится с использованием различных инструментов, но основными ее задачами являются снижение цен и увеличение объемов продаж на рынке.
  7. В эксперты надо взять того, кто считает, что работа займет очень много времени и обойдется очень дорого.
  8. Вас облагают налогами даже после того, как вы перестаете работать
  9. Внутренняя работа: маргинализация и ваш ум дзен
  10. Внутренняя энергия. Количество теплоты. Работа в термодинамике
  11. Вопрос 1. Какие работы относятся к работам на высоте?
  12. Вопрос 31. Функции в Excel. Классификация. Работа с мастером функций.


Последнее изменение этой страницы: 2016-04-09; Просмотров: 1403; Нарушение авторского права страницы


lektsia.com 2007 - 2024 год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! (0.022 с.)
Главная | Случайная страница | Обратная связь