5661. Неоптимальное назначение

 

Возможно, Вы слышали о задаче о назначениях, которая звучит следующим образом. Имеется n × n матрица целых чисел. Из нее следует выбрать n элементов так, чтобы в каждой строке и каждом столбце был выбран в точности один элемент, а сумма выбранных элементов была минимально возможной.

Маленький Мини слышал о задаче и думает что она может быть решена так называемым "жадным алгоритмом". То есть она думает что можно взять наименьший элемент из первой строки, потом наименьший элемент со второй строки, не принадлежащий уже использованной колонке, и так далее. Если в некоторой строке имеется несколько допустимых наименьших элементов, то берется тот, который находится в меньшем столбце.

Ее брат Макси понимает, что это не так. Для доказательства он хочет построить матрицу, для которой алгоритм Мини не будет оптимальным. Помогите ему сделать это.

 

Вход. Одно число n (2 ≤ n ≤ 100).

 

Выход. Вывести целочисленную матрицу n × n, на котором алгоритм Мини даст не оптимальное решение. Если такой матрицы не существует, вывести "Impossible". Матрица должна содержать только неотрицательные числа, не превышающие 100.

 

Пример входа

Пример выхода

2

0 1

1 3

 

 

РЕШЕНИЕ

конструктив

 

Анализ алгоритма

Искомой, например, будет матрица размера n × n, состоящая из единиц, в которой в правом нижнем углу стоит число 10.

 

Пример

При n = 4 искомой будет матрица

 

Реализация алгоритма

Читаем входное значение n.

 

scanf("%d", &n);

 

Выводим матрицу на лету.

 

for(i = 0; i < n; i++)

  for(j = 0; j < n; j++)

  {

    if((i == n - 1) && (j == n - 1))

      printf("%d", 10);

    else

      printf("%d", 1);

 

    if(j == n - 1)

      printf("\n");

    else

      printf(" ");

  }