Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [Delphi] Идентичные матрицы, Паскаль 
:(
    Опции темы
maxxxxx
Дата 19.6.2015, 14:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 1
Регистрация: 19.6.2015

Репутация: нет
Всего: нет



Идентичные матрицы

Имя входного файла: a.in
Имя входного файла: a.out
Максимальное время работы на каждом тесте: 10 секунд

Таблица состоит из N строк и M столбцов. Назовем таблицу целочисленной матрицей, если в каждом ячейке
таблицы стоит целое число. Скажем, что матрица кратна числу p, если все числа в ее ячейках кратны p.
Рассмотрим теперь суммы элементов матрицы по строкам и столбцам соответственно. Обозначим сумму чисел i-й
строки за Hi, а сумму чисел j-го столбца за Vj. Упорядоченный набор чисел (H1,H2....HN,V1,V2...VM)назовем
Почти кратная 5 матрица и ее профиль изображены на рисунке 1.

6 & 7 & 2 \
2 & 2 & 31\
7 & 1 & 7 

Рисунок 1

Если две матрицы A и B имеют одинаковый размер, причем элемент, стоящий на пересечении i-й строки и j-го
столбца в матрице A отличается от соответствующего элемента матрицы B не более чем на p, скажем, что A
отличается от B не более чем на p. Скажем, сто матрица B похожа на матрицу A относительно числа p, если
1. В отличается от А не более чем на p
2. Профили В и А совпадают.
A

6 & 7& 2\
2 & 2 & 31\
7 & 1 & 7

почти кратна 5 


5 & 5 & 5 \
0 & 5 & 30\
10 & 0 & 5 

кратна 5 похожа на А


5 & 5 & 5 \
0 & 0 & 35\
10 & 0 & 5

кратна 5, но не похожа на А 
(рисунок 2)

На рисунке 2 изображены две похожие относительно числа 5 матрицы, первая из них почти кратна 5, а вторая 
кратна 5. Третья матрица на рисунке 2 тоже кратна 5, но не похожа на первую (хотя похожа на вторую).
Дано число p и почти кратна p матрица А. Ваша задача - найти такую матрицу В, чтобы она была кратна p и
похожа на А относительно p.

Формат выходных данных 
На первой строке входного файла находятся целые числа p(1≤p≤10), N и M (1≤N,M≤30). Следующие N строка содержат по M целых неотрицательных чисел, не превышающих 1000, которые являются элементами исходной матрицы A.

Формат выходных данных
Введите в выходной файл Матрицу В по строкам - сначала М элементов первой строки, затем М элементов 
второй и т. д. Разделяйте числа пробелами и/или переводами строк. Заботиться о красивом форматировании таблицы
не надо. Если искомой матрицы не существует, выведите единственное число - (-1). Если решений несколько, выведите любое из них.

пример

a.in 

5 & 3 & 3
6 & 7 & 2
2 & 2 & 31
7 & 1 & 7

a.out

5 & 5 & 5 
0 & 5 & 30
10 & 0 & 5
Помогите написать код программы пожалуйста
PM MAIL   Вверх
Poseidon
Дата 19.6.2015, 14:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Delphi developer
****


Профиль
Группа: Комодератор
Сообщений: 5273
Регистрация: 4.2.2005
Где: Гомель, Беларусь

Репутация: 5
Всего: 133



Для домашних заданий, контрольных и курсовых существует Центр помощи.

Тема перенесена! 



--------------------
Если хочешь, что бы что-то работало - используй написанное, 
если хочешь что-то понять - пиши сам...
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.2053 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.