Разработчику о работе с 1С:Предприятие, Pascal, Паскаль
Решение вопросов, возникающие при автоматизации учета с помощью 1С:Предприятие. Паскаль.
Как вывести массив в виде матрицы паскаль?
14.06.2017 | Автор Дмитрий
Как вывести массив в виде матрицы паскаль?
program Task_Screen_2Mer1; var i, j, i_Min: integer; i_ArrNum: array[1..3, 1..4] of integer; begin WriteLn('Задача, как вывести массив в виде матрицы паскаль:'); WriteLn('Введите 12 (двенадцать) чисел:'); for i := 1 to 3 do // по строкам for j := 1 to 4 do // по столбцам ReadLn(i_ArrNum[i, j]); WriteLn('Вывод массива в виде матрицы на экран'); for i := 1 to 3 do // по строкам for j := 1 to 4 do // по столбцам begin Write(i_ArrNum[i, j], ' '); if j = 4 then WriteLn(); end; //завершение работы программы WriteLn('Нажмите , чтобы выйти.'); ReadLn(); end.
Как вывести массив в виде матрицы паскаль?
Рубрика: Pascal (Паскаль) — задачи и решения
Программирование в «Эврике»
Теперь мы можем присваивать каждому элементу списка A новое значение. Например, мы можем сделать элемент A[0] также равным списку:
A[0]=range[3]
Теперь A будет равно [[0, 1, 2], 1, 2, 3, 4] , то есть объект A[0] будет списком [0, 1, 2] . В свою очередь, мы можем обращаться к отдельным элементам списка A[0] : A[0][0]==0 , A[0][1]==1 , A[0][2]==2 .
На практике часто приходится иметь дело с прямоугольными таблицами данных, также называемых двумерными массивами. Их можно представлять в виде списка из n элементов (строк), каждый из которых является списком из m элементов (столбцов). Тогда к отдельному элементу двумерного массива A можн обращаться, как A[i][j] , где i является номером строки, 0
Итак, создадим массив A из n=3 строк и m=5 столбцов:
n=3 m=5 A=range(n) # A является списком из n строк for i in range(n): A[i]=range(m) # Каждая строка является списком из m элементов
Заполнение массива
Теперь заполним массив нулями. Для этого нам понадобится два вложенных цикла: внешний цикл по всем строкам, а внутренний – по всем столбцам.
for i in range(n): for j in range(m): A[i][j]=0
Если мы захотим записать в массив таблицу умножения, присвоив элементу A[i][j] значение i*j , последнюю строку в этом примере нужно записать в виде A[i][j]=i*j .
Вывод массива на экран
Конечно, можно вывести массив A на экран одной командой print A , но тогда все элементы будут выведены в одну строку:
[[0, 0, 0, 0, 0], [0, 1, 2, 3, 4], [0, 2, 4, 6, 8]]
Но можно вывести массив в виде таблицы, так, чтобы каждая строка массива была выведена на одной строке, а внутри строки числа разделялись одним пробелом, то есть в виде:
A[0][0] A[0][1] A[0][2] A[0][3] A[0][4] A[1][0] A[1][1] A[1][2] A[1][3] A[1][4] A[2][0] A[2][1] A[2][2] A[2][3] A[2][4]
Для этого снова понадобятся два вложенных цикла. Один цикл по всем строкам, другой – по всем столбцам. В результате получаем:
for i in range(n): for j in range(m): print A[i][j], print
Обратите внимание на запятую, поставленную после инструкции print A[i][j] , необходимую для того, чтобы печать продолжалась на этой же строке. А вот инструкцию print без параметров для перехода на новую строку мы даем после завершения внутреннего цикла, то есть после вывода всей строки на экран. Вот что получится:
0 0 0 0 0 0 1 2 3 4 0 2 4 6 8
Считывание с клавиатуры
Теперь рассмотрим проблему считывания массива с клавиатуры в таком же виде. Проблема заключается в том, что функция input позволяет считать только одно значение, записанное в строке и выдаст ошибку при считывании набора чисел, разделенных пробелами. А функция raw_input сможет считать строку как единое целое вместе со всеми пробелами. Разбить строку на отдельные выражения, разделенные пробелами можно при помощи метода split() . Этот метод применяется к строке и возвращает список подстрок, состоящих из непробельных символов и разделенных пробелами. То есть если применить метод split к строке ‘1 2 3’ , то получится список из 3 строк: [‘1’, ‘2’, ‘3’] . Таким образом, мы можем разбить каждую входную строку на отдельные подстроки, а затем преобразовать эти подстроки к числовому виду при помощи функции int . В результате получаем следующий код (предполагается, что массив A из n строк и m столбцов уже создан):
for i in range(n): # Цикл по всем строкам s=raw_input() # Считали строку в переменную s s=s.split() # Разбили s на слова и записали их в виде списка for j in range(m): A[i][j]=int(s[j]) # Элементу A[i][j] присваиваем значение s[j]
Общий пример программы
Теперь объединим это все в одну программу, которая считывает с клавиатуры числа n и m (заданные в одной строке), затем создает массив из n строк и m столбцов, затем считывает его с клавиатуры построчно, затем увеличивает каждый элемент массива на 1, наконец, печатает результат:
# Считываем размеры массива s=raw_input() s=s.split() n=int(s[0]) m=int(s[1]) # Создаем массив A=range(n) for i in range(n): A[i]=range(m) # Считываем массив с клавиатуры for i in range(n): s=raw_input() s=s.split() for j in range(m): A[i][j]=int(s[j]) # Увеличиваем все элементы на 1 for i in range(n): for j in range(m): A[i][j]=A[i][j]+1 # Выводим массив на экран for i in range(n): for j in range(m): print A[i][j], print
Сложный пример обработки массива
Пусть дан квадратный массив из n строк и n столбцов. Необходимо элементам, находящимся на главной диагонали проходящей из левого верхнего угла в правый нижний (то есть тем элементам A[i][j] , для которых i==j ) присвоить значение 1 , элементам, находящимся выше главной диагонали – значение 0, элементам, находящимся ниже главной диагонали – значение 2. То есть получить такой массив (пример для n==4 ):
1 0 0 0 2 1 0 0 2 2 1 0 2 2 2 1
Рассмотрим несколько способов решения этой задачи. Элементы, которые лежат выше главной диагонали – это элементы A[i][j] , для которых ij . Таким образом, мы можем сравнивать значения i и j и по ним определять значение A[i][j] . Получаем следующий алгоритм:
for i in range(n): for j in range(n): if ij: A[i][j]=2 else: A[i][j]=1
Данный алгоритм плох, поскольку выполняет одну или две инструкции if для обработки каждого элемента. Если мы усложним алгоритм, то мы сможем обойтись вообще без условных инструкций.
Сначала заполним главную диагональ, для чего нам понадобится один цикл:
for i in range(n): A[i][i]=1
Затем заполним значением 0 все элементы выше главной диагонали, для чего нам понадобится в каждой из строк с номером i присвоить значение элементам A[i][j] для j = i+1 , . n-1 . Здесь нам понадобятся вложенные циклы:
for i in range(n): for j in range(i+1,n): A[i][j]=0
Аналогично присваиваем значение 2 элементам A[i][j] для j = 0 , . i-1 :
for i in range(n): for j in range(0,i): A[i][j]=2
Можно также внешние циклы объединить в один и получить еще одно, более компактное решение:
for i in range(n): for j in range(0,i): A[i][j]=2 A[i][i]=1 for j in range(i+1,n): A[i][j]=0
Форматирование чисел при выводе
Допустим, мы заполним массив таблицей умножения: A[i][j]=i*j как в примере в начале раздела. Если мы теперь попробуем вывести этот массив на экран, разделяя элементы в строке одним пробелом, то из-за того, что числа имеют различную длину столбцы таблицы окажутся неровными:
0 0 0 0 0 0 0 0 0 0 0 1 2 3 4 5 6 7 8 9 0 2 4 6 8 10 12 14 16 18 0 3 6 9 12 15 18 21 24 27
Для того, чтобы получить ровные столбцы необходимо, выводить числа так, чтобы одно выводимое число имело длину, например, ровно в 2 символа, а «лишние» позиции были бы заполнены пробелами.
0 0 0 0 0 0 0 0 0 0 0 1 2 3 4 5 6 7 8 9 0 2 4 6 8 10 12 14 16 18 0 3 6 9 12 15 18 21 24 27
Без лишних комментариев покажем, как в программе указать, что целое число x нужно выводить так, чтобы оно занимало ровно две позиции: print «%2d» % x . Здесь, естественно, можно заменить значение x на то значение, которое необходимо напечатать, а число 2 на любую другую ширину поля.
Итак, для печати ровной таблицы умножения можно воспользоваться следующим кодом:
for i in range(n): for j in range(m): print «%2d» % A[i][j],
Как вывести двумерный массив?
Обычно двумерные массивы выводятся на экран в табличной форме, или поэлементно. Во втором случае в каждой строке находиться одно значение, перед которым указано название массива, а в скобках индексы элементов.
Программа для вывода двумерного массива в виде таблицы
program Print2dArray; const rowCount = 4; colCount = 6; var arr : array [1..rowCount, 1..colCount] of integer; row, col : integer; begin randomize; for row := 1 to rowCount do for col := 1 to colCount do arr[row, col] := random(100); writeln('Печать массива'); for row := 1 to rowCount do begin for col := 1 to colCount do write(arr[row, col]:4); writeln; end; readln; end.
Результат табличного вывода массива в консоль
Вывод массива по одному элементу в строке, с названием массива и значениями индексов
writeln('Печать массива'); for row := 1 to rowCount do for col := 1 to colCount do writeln('A[', row,', ', col, '] =', arr[row, col]:4);
вывести двумерный массив спиралью
в задаче ниже нужно написать метод, которому передается два значения для двумерного массива, а именно кол-во строк и кол-во столбцов. этот метод должен заполнить массив так, чтобы когда его выводишь на экран, числа шли спиралью и по часовой стрелке:
1 2 3 10 11 4 9 12 5 8 7 6
сама задача: int[][] spiral(int rows, int columns)
Возвращает двумерный массив в виде таблицы, содержащий числа от 1 до rows * columns. Размер таблицы будет определяться заданными параметрами. Числа заполняют «таблицу» по часовой стрелке от верхнего угла по спирали. подскажите, пожалуйста, кто знает, что пошло не так в моем решении
static int[][] spiral(int rows, int columns) < int[][] spiral = new int[rows][columns]; int sum = rows * columns; int x = rows; int y = columns; int counter = 1; rows += 1; columns +=1; do < rows -= 1; columns -=1; // должен по идее передавать значение первой строки for (int i = 0; i < 1; i ++)< for (int a = 0; a < columns - 1; a ++)< spiral[i][a] = counter; counter++; >> // а этот по идее последнего столбца for (int i = columns-1; i < columns; i ++)< for (int a = 0; a < rows - 1; a ++)< spiral[a][i] = counter; counter++; >> //а этот самой нижней строки и так далее for (int i = rows - 1; i < rows; i++)< for (int a = columns - 1; a < 0; i--)< spiral[i][a] = counter; counter ++; >> > while (counter