Заглавная страница Избранные статьи Случайная статья Познавательные статьи Новые добавления Обратная связь FAQ Написать работу КАТЕГОРИИ: АрхеологияБиология Генетика География Информатика История Логика Маркетинг Математика Менеджмент Механика Педагогика Религия Социология Технологии Физика Философия Финансы Химия Экология ТОП 10 на сайте Приготовление дезинфицирующих растворов различной концентрацииТехника нижней прямой подачи мяча. Франко-прусская война (причины и последствия) Организация работы процедурного кабинета Смысловое и механическое запоминание, их место и роль в усвоении знаний Коммуникативные барьеры и пути их преодоления Обработка изделий медицинского назначения многократного применения Образцы текста публицистического стиля Четыре типа изменения баланса Задачи с ответами для Всероссийской олимпиады по праву Мы поможем в написании ваших работ! ЗНАЕТЕ ЛИ ВЫ?
Влияние общества на человека
Приготовление дезинфицирующих растворов различной концентрации Практические работы по географии для 6 класса Организация работы процедурного кабинета Изменения в неживой природе осенью Уборка процедурного кабинета Сольфеджио. Все правила по сольфеджио Балочные системы. Определение реакций опор и моментов защемления |
Вывод элементов множества на экранСодержание книги
Поиск на нашем сайте
Используем символьную переменную ch (Var ch: char;), перебираем все значения символов, начиная с пробела (код #32) и, если символ есть в множестве, выдаем его на экран. For ch:=#32 to #255 do If ch in M then write(ch); Ввод множества символов Множество можно задать в разделе констант. Например, так Const M: set of char = ['A'..'Z']; R: set of char = ['0'..'9']; Можно получить в результате присваивания, описав в разделе переменных (Var M:set of char;) и присвоив в программе M:= ['0'..'9', '+', '-']; При вводе с клавиатуры или из текстового файла, заданное множество лучше вводить в виде строки, из символов которой потом легко получить множество или каждый символ сразу добавлять к множеству. Количество различных символов в строке Все пояснения в тексте программы. Var M:set of char; S: string; k, i: integer; ch: char; Begin S:='мама мыла раму'; M:=[]; {пустое множество - обязательно} к:=0; {обязательно обнуляем счетчик} For i:=1 to Length(S) do If Not (S[i] In M) then {символа еще нет мн-ве} Begin k:=k+1; {добавляем символ к множеству,} {чтобы не посчитать его повторно} M:=M+[s[i]]; End; Write(k); Readln; End. Двухмерные массивы (матрицы) Описание матрицы. Const n=4; m=5; Type matrix=array[1..n, 1..n] of Real; {или другой тип} Var A:matrix; На рис.2. показан вид описанной матрицы. Обратите внимание, что первый индекс – номер строки, второй - -номер столбца.
Рис. 2. Вид матрицы. Ввод элементов матрицы. Элементы вводятся последовательно по строкам, i – номер строки, j – номер столбца. For i:=1 to n do For j:=1 to m do Read(A[i, j]); Если конкретный размер матрицы может меняться, то следует описать матрицу с запасом (максимальный размер по условию задачи), и вводить размеры матрицы, а затем ее элементы.
Const max=100; Type matrix=array[1..max, 1..max] of Real; { или другой тип} Var A: matrix; Begin Write ('Введите число строк'); Radln (n); Write ('Введите число столбцов'); Radln (m); Write ('Введите', m*n, 'элементов матрицы'); For i:=1 to n do For j:=1 to m do Read (A[i, j]); Вывод элементов матрицы. Вывод матрицы на экран или в текстовый файл нужно производить в «матричной форме» (по строкам и столбцам), разделяя числа пробелами. For i:=1 to n do Begin For j:=1 to m do Write (A[i, j], ' ');{ выдаем строку} Writeln {переводим курсор на следующую строку} End; Основные алгоритмы работы с матрицами. Сумма элементов матрицы. Простой алгоритм не требует дополнительных пояснений. Еще раз обращаем внимание на то, что переменная S должна быть обнулена. S:=0; For i:= 1 to n do For j:= 1 to m do S:= S+ a[i, j]; Сумма главной диагонали квадратной матрицы. Обращаем внимание на то, что элементы главной диагонали имеют равные номера строк (первый индекс) и номера столбцов (второй индекс). S:=0; For i:= 1 To n Do S:=S+a[i, i]; Сумма побочной диагонали квадратной матрицы. Посмотрите на индексы побочной диагонали матрицы, первый изменяется по возрастанию, второй по убыванию. S:=0; For i:= 1 To n Do S:=S+a[i, n+1-i]; Транспонирование матриц. Строки исходной матрицы становятся столбцами транспонированной. Исходная матрица (а) имеет n строк и m столбцов. Транспонированная матрица (в) имеет m строк и n столбцов. For i:= 1 to n Do For j:= 1 to m Do b[j, i]:= a [i, j]; Транспонирование матрицы в том же массиве (транспонирование квадратной матрицы). Здесь без рабочей ячейки не обойтись. For i:= 1 To n-1 Do For j:= i To n Do Begin r:= a[i, j]; a[i, j]:= a[j, i]; a[j, i]:= r; End; Умножение матриц. Дана матрица A размерами n*m и матрица B – m*k. После умножения получим матрицу C размерами n*k. Умножение ведем по формуле Cij= S ait*btj For i:= 1 To n Do For j:= 1 To k Do begin S:=0; For t:= 1 To m Do S:= S+A[i, t]*B[t, j]; C[i, j]:= S; end; Работа с фрагментами матриц Рассмотрим квадратную матрицу. Решим четыре похожие задачи по одной простой схеме.
Рис.3. Квадратная матрица Задачи: 1) сумма элементов на главной диагонали и выше нее. 2) сумма элементов на главной диагонали и ниже нее. 3) сумма элементов на побочной диагонали и выше нее. 4) сумма элементов на побочной диагонали и ниже нее. Для первой задачи суммирование элементов первой строки нужно начинать с первого элемента до конца строки, второй строки со второго элемента и так до последней строки, где в суммировании участвует только последний элемент Для второй задачи из первой строки нужно взять только первый элемент, из второй строки два элемента и так до последней строки. Для третьей задачи суммирование элементов из первой строки нужно взять все элементы, из второй строки на один меньше и так до последней строки. Для четвертой задачи в первой строке нужно взять только последний элемент, во второй строке два последних и так до последней строки.
|
||||||||||||||||||||||||||||||||||||||||
Последнее изменение этой страницы: 2019-12-25; просмотров: 338; Нарушение авторского права страницы; Мы поможем в написании вашей работы! infopedia.su Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав. Обратная связь - 3.133.127.131 (0.006 с.) |