Требуется написать программу которая заполняет массив размерности nxn по заданному правилу

Создать и заполнить массив NxN, где N — четное число больше или равно 2, данными согласно следующим правилам. В центре матрицы блок 2х2 заполненный нулями, Далее идут строки столбцы в 1 ячейку значение которых последовательно увеличивается на 1. Помогите решить ,и если не сложно с пояснением пожалуйста! Спасибо.

Пример таблицы 4х4 1111 1001 1001 1111 Пример таблицы 6х6 222222 211112 210012 210012 211112 222222 Пример таблицы 8х8 33333333 32222223 32111123 32100123 32100123 32111123 32222223 33333333

Задачу получилось решить вот таким образом

int[][] array = new int[4][4]; int count = 0; for (int i = 0; i < array.length; i++)< for (int j = 0; j < array.length; j++)< array[i][j] =1; count++; if (count == 6)< array[i][j] = 0; >if (count == 7)< array[i][j] = 0; >if (count == 10) < array[i][j] = 0; >if (count == 11) < array[i][j] = 0; >> > System.out.println(Arrays.deepToString(array));

Если заполнять так то не понятно как в центр добавить нули 0

Как решать задачи по программированию. Пример: задача «Спираль»


public static int[][] buildArr(int n) < int[][] arr = new int[n][n]; for (int i = 0, v = n / 2; v— >0; i++) < for (int j = i; j < n — i; j++) < arr[i][j] =1; // верхняя строка arr[j][i] =1 ; // левая колонка arr[n-1-i][j] = 1; // нижняя строка arr[j][n-1-i] = 1; // правая колонка >> return arr; >

Источник: ru.stackoverflow.com

Домашнее задание для ПО 2.11 по системному программированию от 22.04.20
учебно-методический материал

Требуется написать программу, которая заполняет массив размерности nxn по заданному правилу: То есть, заполнение массива должно быть по диагонали, сверху-вниз, слева-направо. Причем заполнение еще и зигзагообразное.

Скачать:

Предварительный просмотр:

Сорок седьмое задание

Требуется написать программу, которая заполняет массив размерности nxn по заданному правилу: То есть, заполнение массива должно быть по диагонали, сверху-вниз, слева-направо. Причем заполнение еще и зигзагообразное.

using namespace std;

const int colum = 10; // количество столбцов массива

const int row = 10; // количество строк массива

int x, y, // Координаты текущего элемента массива

value = 1; // значение, которым заполняется массив

// зполнение первой половины массива по диагонали, зигзагом, начиная

// слева и сверху, заканчивая побочной диагональю

for (int diag = 0; diag

if (diag % 2 == 0) // по четным диагоналям

x = 0; // х-координата первого лемента массива на диагонали — diag

y = diag; // у-координата элемента массива на диагонали — diag

while (y >= 0) // пока y-координата находится в верхней части диагонали

Читайте также:
Служба антивирусной программы Microsoft defender не отключается

array[x][y] = value; // записать значение в массив

ЗАПОЛНИТЬ МАССИВ С КЛАВИАТУРЫ | ВВОД МАССИВА С КОНСОЛИ C# | СИ ШАРП УРОКИ | ДОМАШНИЕ ЗАДАНИЯ # 6

x++; // по горизонтали, смещаемся влево

y—; // по вертикали, смещаемся вниз

else // по нечетным диагоналям

x = diag; // х-координата элемента массива на диагонали — diag

y = 0; // у-координата первого элемента массива на диагонали — diag

while (x >= 0) // пока x-координата находится в левой части диагонали

array[x][y] = value; // записать значение в массив

x -= 1; // по горизонтали, смещаемся вправо

y += 1; // по вертикали, смещаемся вверх

// заполнение второй половины массива по диагонали, зигзагом, начиная

// слева и сверху, заканчивая последним элементом массива

for (int diag = 1; diag

if (diag % 2 == 0) // по четным диагоналям

x = 9; // х-координата первого элемента массива на диагонали — diag

y = diag; // у-координата элемента массива на диагонали — diag

x—; // по горизонтали, смещаемся влево

y++; // по вертикали, смещаемся вниз

else // по не четным диагоналям

x = diag; // х-координата первого элемента к-ой диагонали

y = 9; // у-координата первого элемента к-ой диагонали

x++; // по горизонтали, смещаемся вправо

y—; // по вертикали, смещаемся вверх

> // конец цикла for (заполнение второй половины массива)

// вывод масиива на экран

for (int ix = 0; ix

for (int jx = 0; jx

По теме: методические разработки, презентации и конспекты

Домашнее задание для ПО 1.11 по системному программированию от 04.02.20

Шестнадцатеричное представление Представим, что необходимо просмотреть содержимое некотоpых байт в памяти. Требуется oпределить содержимое четырех последовательных байт (двух слов), которые имеют двои.

Домашнее задание для ПО 1.11 по системному программированию от 11.02.20

Сегменты Сегментом называется область, которая начинается на границе параграфа, то есть, по любому адресу, который делится на 16 без остатка. Хотя сегмент может располагаться в любом месте памяти и им.

Источник: nsportal.ru

Заполнение массива по правилу

Задача. Заполнить массив А размером NxM «змейкой» следующим образом:

8 9 10 11 12 13 14

15 16 17 18 19 20 21

22 23 24 25 26 27 28

Для того, чтобы заполнить, надо вывести правило заполнения, а оно в данном случае будет таким:

если ряд нечетный, то A[i, j]=(i-1)*m+j;

если ряд четный, то A[i, j]=i*m-j+1.

По этому правилу и составляем процедуру заполнения:

Procedure FillArray(Var X: MyArray2; n, m: integer);

for i:= 1 to n do

for j:= 1 to m do

Задание. Вставьте в программу-шаблон рассмотренные подпрограммы и организуйте выбор одной из них через меню. Дополните подпрограммы, не содержащие пояснений, соответствующими комментариями. Сохраните файл на дискете. Листинг сдайте учителю для проверки.

Читайте также:
Блок схемой программы является

Задачи для самостоятельного решения

Выберите задачи из предложенного списка в соответствии с Вашим порядковым номером в журнале. При решении задач используйте программу-шаблон. Не забудьте пояснять решение задачи комментариями. Приготовьтесь объяснить решение задач учителю.

1. Найти сумму и количество элементов с заданным условием (хранить эти значения в массивах):

1) элементы каждого столбца, кратные k1 или k2;

2) элементы каждого столбца, попадающие в промежуток [А..В];

3) элементы каждого столбца, которые являются простыми числами;

4) элементы каждого столбца положительны и лежат выше главной диагонали;

5) отрицательные элементы каждого столбца, меньшие заданного числа а;

6) элементы каждого столбца, меньшие среднего арифметического элементов каждого столбца;

7) элементы каждой строки, больших среднего арифметического элементов данной строки;

8) максимальные элементы каждой строки;

9) отрицательные элементы каждой строки;

10) элементы каждой строки, равные сумме соседних с ним элементов;

11) элементы каждой строки, равные элементу в том же столбце, но в предыдущей строке.

2. Найти и вывести на экран индексы заданных элементов массива (если их нет выдать соответствующее сообщение):

1) четных элементов каждой строки и нечетных элементов каждого столбца;

2) симметричных чисел;

3) первых k отрицательных элементов каждого столбца;

4) последних k отрицательных элементов каждой строки;

5) последних k отрицательных элементов каждого столбца;

6) равных между собой элементов каждого столбца;

7) элементов, являющимися действительными числами;

8) элементов, являющихся трехзначными числами;

9) элементов, не имеющих целой части;

10) элементов, являющихся числами, сумма цифр которых равна заданному числу;

11) элементов, являющихся числами, первая цифра которых равна заданной.

3. Используя функцию булева типа, определить:

1) есть ли в данном массиве отрицательный элемент;

2) есть ли два одинаковых элемента;

3) есть ли данное число А среди элементов массива;

4) есть ли в заштрихованной области массива (рис. а) элемент, равный введенному с клавиатуры числу (массив имеет размерность nxn);

5) есть ли в заштрихованной области массива (рис. b) элемент, равный введенному с клавиатуры числу (массив имеет размерность nxn):

6) есть ли в заштрихованной области массива (рис. c) элемент, равный введенному с клавиатуры числу (массив имеет размерность nxn):

7) является ли массив логическим квадратом, то есть суммы по всем горизонталям, вертикалям и двум диагоналям должны быть равны;

8) добавить к предыдущему условию, что сумма должна быть равна данному числу А;

9) состоящая только из положительных элементов;

Читайте также:
Что такое клиентская программа

10) состоящая только из положительных или нулевых элементов;

11) состоящая только из элементов, принадлежащих промежутку от А до В.

4. Измените исходный массив в соответствии с заданием:

1) в каждой строке сменить знак максимального по модулю элемента на противоположный;

2) отрицательный последний элемент каждого столбца заменить нулем;

3) положительные элементы умножить на первый элемент соответствующей строки, а отрицательные – на последний;

4) заменить все элементы строки с номером k и столбца с номером р на противоположные по знаку (элемент, стоящий на пересечении, не изменять);

5) к элементам столбца k1 прибавить элементы столбца k2;

6) переверните в массиве каждую третью строку;

7) поменяйте местами заданные элементы каждого столбца;

8) добавьте к массиву столбец, содержащий максимальный элемент соответствующей строки, и строку содержащую минимальный элемент соответствующего столбца;

9) найти максимальный элемент каждой строки и заменить им все минимальные элементы строки;

10) найти минимальный и максимальный элементы столбца и заменить их суммой последний элемент;

11) переверните в массиве каждую половину каждого столбца.

5. Решите задачу на заполнение массива по определенному правилу.

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

2) Заполнить массив А размером NxM следующим образом:

21 20 19 18 17 16 15

8 9 10 11 12 13 14

3) Заполнить массив А размером NxM следующим образом:

8 0 9 0 10 0 11

4) Заполнить квадратный массив В размером NxN следующим образом:

1 4 7 10 13 17 20

2 5 8 11 14 18 21

3 6 9 12 15 19 22

5) Заполнить квадратный массив В размером NxN следующим образом:

6 8 13 19 23 30

7 14 18 24 29 31

15 17 25 28 32 35

16 26 27 33 34 36

6) Заполнить квадратный массив В размером NxN (N<10)следующим образом:

11 12 13 14 15 16 17

21 22 23 24 25 26 27

7) Заполнить квадратный массив В размером NxN следующим образом:

8) Заполнить квадратный массив В размером NxN следующим образом:

9) Заполнить квадратный массив В следующим образом: первая строка – числа Фибоначчи, а каждый столбец продолжает ряд Фибоначчи от элемента, находящегося в первой строке.

10) Заполнить массив рядом натуральных чисел, расположив их закручивающейся спиралью по часовой стрелке.

11) Заполнить массив рядом натуральных чисел, расположив их раскручивающейся спиралью против часовой стрелки.

Занятие III

Источник: infopedia.su

Рейтинг
( Пока оценок нет )
Загрузка ...
EFT-Soft.ru