Студопедия

КАТЕГОРИИ:


Архитектура-(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)

Использование массивов в качестве параметров




Массив является ссылочным типом и если массив является параметром метода, то передача его всегда осуществляется по ссылке, независимо от наличия ключевого слова ref. Поскольку массивы являются ссылочными типами, метод может изменять значения элементов. Наличие квадратных скобок после типа в подписи метода означает, что параметром является массив.

Пример 5.3. Максимальный элемент массива а размера 6 поменять местами с максимальным элементом массива b размера 8. Оформить метод для поиска максимального элемента одномерного массива. Результатом метода являются значение и индекс максимального элемента.

 

using System;

class Program

{

static void maxx(int[] x, ref int xmax, ref int imax)

{

xmax = x[0];

imax = 0;

for (int i = 0; i < x.Length; i++)

{

if (x[i] >= xmax)

{

xmax = x[i];

imax = i;

}

}

}

static void Main()

{

int[] a = new int[] { 1, 7, 3, 5, 6, 2 };

int[] b = new int[] { 4, 2, 1, 8, 9, 3, 5, 6 };

for (int i = 0; i < a.Length; i++)

{

Console.Write("{0:d} ", a[i]);

}

Console.WriteLine();

for (int i = 0; i < b.Length; i++)

{

Console.Write("{0:d} ", b[i]);

}

Console.WriteLine();

Console.WriteLine();

int amax = 0, bmax = 0, iamax = 0, ibmax = 0;

maxx(a, ref amax, ref iamax);

maxx(b, ref bmax, ref ibmax);

a[iamax] = bmax; b[ibmax] = amax;

for (int i = 0; i < a.Length; i++)

{

Console.Write("{0:d} ", a[i]);

}

Console.WriteLine();

for (int i = 0; i < b.Length; i++)

{

Console.Write("{0:d} ", b[i]);

}

Console.WriteLine();

}

}

В методе maxx предусмотрена возможность обработки массивов разного размера. Для определения размера массива-аргумента, обрабатываемого в каждом конкретном случае, используется свойство массива Length.

В методе Main для указания верхней границы индексов в циклах также используется свойство Length, (хотя можно было бы использовать и различные константы).

Пример 5.4. Просуммировать элементы строки матрицы d размером n*m (программа реализована для n = 3, m = 4), содержащей максимальный элемент матрицы. Поиск максимального элемента матрицы осуществлять в методе.

Исходный массив d представим в виде одномерной последовательности с нумерацией индексов от 0 до n*m-1 (в данном примере n=3, m=4, n*m–1 = 11). Возвращаемым значением метода является номер строки (нумерация с 0), содержащей максимальный элемент матрицы. После нахождения максимального элемента матрицы необходимо просуммировать следующие подряд m элементов, начиная с первого элемента в строке (это элемент с номером ns*m, где ns – номер строки, содержащей максимальный элемент матрицы, строки нумеруются от 0 до n – 1, m– количество элементов в строке).

Результатом работы метода является одно значение – номер строки, содержащей максимальный элемент матрицы. Возможны два варианта организации метода: получить результат как возвращаемое методом значение (вариант 1) или использовать для этого параметр метода (вариант 2). Далее приводятся оба варианта кода. В методе находится индекс максимального элемента в одномерной последовательности imax. Номер строки, содержащей этот элемент, определяется делением этого значения индекса на количество элементов в строке. Вспомним, что при делении двух целых чисел дробная часть отбрасывается.

Вариант 1. Метод возвращает значение.

using System;

class Program

{

const int m = 4;

static int maxx(int[] x)

{

int xmax = x[0];

int imax = 0;

for (int i = 0; i < x.Length; i++)

{

if (x[i] > xmax)

{

xmax = x[i];

imax = i;

}

}

return imax / m;

}

static void Main()

{

int[] d = new int[] { 1, 7, 3, 5, 6, 2, 9, 3, 8, 3, 6, 1 };

 

for (int i = 0; i < d.Length; i++)

{

Console.Write("{0:d} ", d[i]);

}

Console.WriteLine();

int s = 0;

int ns = maxx(d) * m;

for (int k = ns; k <= ns + m - 1; k++)

s = s + d[k];

Console.WriteLine(s);

Console.ReadKey();

}

}

 

Вариант 2. Для получения результата используется параметр метода.

using System;

class Program

{

const int m = 4;

static void maxx(int[] x, ref int di)

{

int xmax = x[0];

int imax = 0;

for (int i = 0; i < x.Length; i++)

{

if (x[i] > xmax)

{

xmax = x[i];

imax = i;

}

}

di = imax / m;

}

static void Main()

{

int[] d = new int[] { 1, 7, 3, 5, 6, 2, 9, 3, 8, 35, 6, 1};

int di = 0;

for (int i = 0; i < d.Length; i++)

{

Console.Write("{0:d} ", d[i]);

}

Console.WriteLine();

int s = 0;

maxx(d, ref di);

int ns = di * m;

for (int k = ns; k <= ns + m - 1; k++)

s = s + d[k];

Console.WriteLine(s);

Console.ReadKey();

}

}




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


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


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



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




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