Форум программистов, компьютерный форум, киберфорум
Наши страницы

Матрицу K(m, n) заполнить следующим образом - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Заполнить матрицу по правилу http://www.cyberforum.ru/cpp-beginners/thread727515.html
Матрицу K(m, n) заполнить следующим образом. Элементам, находящимся на периферии (по периметру матрицы), присвоить значение 1; периметру оставшейся подматрицы - значение 2 и так далее до заполнения...
C++ Написать функцию, определяющую НОД(наибольший общий делитель) двух целых чисел Написать функцию, определяющую НОД(наибольший общий делитель) двух целых чисел. НОД-это наибольшее целое, на которое делятся оба числа. Для решения использовать алгоритм Евклида, который состоит в... http://www.cyberforum.ru/cpp-beginners/thread727494.html
C++ Организовать циклический список
Привет, помогите пожалуйста хоть не много Организовать циклический список, содержащий данные о клиентах( наименования, шифр). Вывести на экран список, используя функцию. Разбить данный список на...
C++ Разница int, short, unsigned int, unsigned short
Есть например цикл который проходит по массиву в котором 100 элементов. В чем практическая выгода и разница в истоьзовании типов short, int, unsigned short. Я понимаю, что у них различный диапазон...
C++ Как попасть в область на координате (х,у) ? http://www.cyberforum.ru/cpp-beginners/thread727452.html
Построить программу, которая вводит координаты точки (x, y) и определяет, попадает ли точка в заштрихованную область на рисунке. Попадание на границу области считать попаданием в область.
C++ Метод пузырька Дано n (n<=32000) натуральных чисел xi, (xi<m). Необходимо установить, можно ли разбить их на пары таким образом, чтобы сумма чисел в каждой паре не превышала m (m<=100). Файл input.txt... подробнее

Показать сообщение отдельно
go
Эксперт С++
3586 / 1366 / 128
Регистрация: 16.04.2009
Сообщений: 4,528
11.12.2012, 16:31
Ольга Артуровна, если правильно понял задание, то вот для квадратных матриц
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#include <iostream>
#include <random>
 
#define ROWS 10
#define COLUMNS 10
 
int main()
{
   int mt[ROWS][COLUMNS];
   std::mt19937 gen(time(0));
   std::uniform_int_distribution<> distr(10, 99);
   
   for (int i = 0; i < ROWS; ++i)
      for (int j = 0; j < COLUMNS; ++j)
         mt[i][j] = distr(gen);
         
   for (int i = 0; i < ROWS; ++i)
   {
      for (int j = 0; j < COLUMNS; ++j)
         std::cout << mt[i][j] << " ";
      std::cout << std::endl;
   }
   
   for (int i = 0, val = 0; i < ROWS / 2; ++i, ++val)
   {
      for (int j = i; j < (COLUMNS - i); ++j)
      {
         mt[i][j] = val;
         mt[ROWS - i - 1][j] = val;
         mt[j][i] = val;
         mt[j][COLUMNS - i - 1] = val;
      }
   }
   
   for (int i = 0; i < ROWS; ++i)
   {
      for (int j = 0; j < COLUMNS; ++j)
         std::cout << mt[i][j] << " ";
      std::cout << std::endl;
   }
 
}
Result
Код
stdout: 
46 52 56 29 82 10 56 87 81 85 
38 22 39 29 10 74 94 15 69 50 
40 44 68 98 57 10 28 46 98 64 
51 30 33 87 57 78 75 92 65 25 
22 63 80 14 64 78 90 61 11 82 
87 64 20 18 84 51 69 14 37 13 
30 31 35 65 99 31 15 92 77 27 
32 93 49 31 95 23 54 26 57 61 
35 34 99 22 58 91 19 69 65 16 
45 84 64 24 85 60 49 75 20 52 
0 0 0 0 0 0 0 0 0 0 
0 1 1 1 1 1 1 1 1 0 
0 1 2 2 2 2 2 2 1 0 
0 1 2 3 3 3 3 2 1 0 
0 1 2 3 4 4 3 2 1 0 
0 1 2 3 4 4 3 2 1 0 
0 1 2 3 3 3 3 2 1 0 
0 1 2 2 2 2 2 2 1 0 
0 1 1 1 1 1 1 1 1 0 
0 0 0 0 0 0 0 0 0 0
http://liveworkspace.org/code/22DEU1$18
1
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru