Максимальная выполнимость формул в 2-КНФ: различия между версиями

Перейти к навигации Перейти к поиску
м
Строка 77: Строка 77:




'''Теорема 2 (Алон, Галил, Маргалит [1]). Пусть A и B – матрицы размера n x n с элементами из <math>\Z [-W, W] \cup{ \infty}</math>. Тогда произведение A ®d B может быть вычислено за время O(Wn! log n).'''
'''Теорема 2 (Алон, Галил, Маргалит [1]). Пусть A и B – матрицы размера n x n с элементами из <math>\Z [-W, W] \cup{ \infty}</math>. Тогда произведение <math>A \otimes_d B</math> может быть вычислено за время <math>O(W \; n^{\omega} \; log \; n)</math>.'''


Доказательство (набросок). Заменим 1 запись в A и B на 2W + 1 следующим образом. Определим матрицы A0 и B0, где и x – переменная. Положим C = A0 x B0. Тогда
Доказательство (набросок). Заменим элементы <math>\infty</math>в A и B на 2W + 1 следующим образом. Определим матрицы A' и B', где и x – переменная. Положим C = A0 x B0. Тогда


На следующем шаге выберем такое число x, чтобы из суммы произвольных степеней x было легко определить наибольшую степень x, встречающуюся в сумме; эта наибольшая степень сразу же дает минимум A[i; k] + B[k; j]. Каждый C[i,j] – это полином от x с коэффициентами из Z[0; n]. Предположим, что каждый C[i,j] оценивается при x = (n + 1). Тогда каждый элемент C[i,j] можно рассматривать как (n + 1)-арное число, а положение старшей значащей цифры этого числа дает минимум A[i; k] + B[k;j].
На следующем шаге выберем такое число x, чтобы из суммы произвольных степеней x было легко определить наибольшую степень x, встречающуюся в сумме; эта наибольшая степень сразу же дает минимум A[i; k] + B[k; j]. Каждый C[i,j] – это полином от x с коэффициентами из Z[0; n]. Предположим, что каждый C[i,j] оценивается при x = (n + 1). Тогда каждый элемент C[i,j] можно рассматривать как (n + 1)-арное число, а положение старшей значащей цифры этого числа дает минимум A[i; k] + B[k;j].
4640

правок

Навигация