09.12.2017, 20:51
|
Интересующийся
|
|
Регистрация: 09.12.2017
Сообщений: 12
|
|
найти кратчайшее покрытие
1. Ищется столбец с минимальным числом единиц. Если таковых несколько, то выбирается любой (для определенности, допустим, самый левый).
2. Среди строк, покрывающих этот столбец, ищется строка с максимальным числом единиц и заносится в покрытие (следовательно, удаляется из матрицы); если же таких строк несколько, то выбирается любая из них (для определенности, допустим, самая верхняя).
3. Удаляются все столбцы, которые покрывает полученная строка.
Дали такое задание. Может кто подскажет.
|
|
10.12.2017, 15:00
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,108
|
|
булевая матрица, метод Закревского
без комментариев...
<!DOCTYPE html>
<html>
<head>
<title>Untitled</title>
<meta charset="utf-8">
</head>
<body>
<script>
function s(a) {
return a.reduce(function(a, b) {
return a + b
}, 0)
}
function c(a) {
return a[0].reduce(function(e, b, g) {
e[g] = [];
for (b = 0; b < a.length; b++) e[g].push(a[b][g]);
return e
}, {})
}
function fn(a, e) {
return Object.keys(a).sort(function(b, g) {
return e ? s(a[g]) - s(a[b]) : s(a[b]) - s(a[g])
})[0]
}
function r(a, e) {
return e.reduce(function(b, e, h) {
e && (b[h] = a[h]);
return b
}, {})
}
function ff(a, e) {
return a.map(function(a) {
return a.filter(function(a, b) {
return 0 == e[b]
})
})
}
function print(a, e, b) {
a = a.reduce(function(a, b) {
return a + "<div>" + JSON.stringify(b) + "</div>"
}, e);
document.body.insertAdjacentHTML("beforeEnd", a + b)
}
var m = [
[1, 0, 1, 0, 0, 0],
[0, 0, 0, 1, 1, 0],
[0, 1, 0, 1, 0, 0],
[0, 0, 1, 0, 1, 1],
[1, 1, 1, 0, 1, 0]
],
temp = "абвгдежзи".split("");
temp.length = m.length;
for (var res = []; 2 < m.length;) {
print(temp, "", "");
print(m, "", "");
var d = c(m),
n = fn(d),
t = d[n],
f = r(m, t),
k = fn(f, !0);
res.push(temp.splice(k, 1)[0]);
var v = m.splice(k, 1)[0];
m = ff(m, v)
}
print([res.sort()], "<b>", "</b>");
</script>
</body>
</html>
|
|
11.12.2017, 18:32
|
Интересующийся
|
|
Регистрация: 09.12.2017
Сообщений: 12
|
|
А если я сам выбираю размерность матрицы и заполняю, как мне для моей матрицы применить данный метод
<section class="lib" id="oms_blok1">
<h2 style="text-align: center;">матрицы</h2>
<div class="calc" id="frtabl">
Размер матрицы:
<select onchange="oms_mhwA(this.value)">
<option value="2">2×2</option>
<option value="3" selected="selected">3×3</option>
<option value="4">4×4</option>
<option value="5">5×5</option>
<option value="6">6×6</option>
<option value="7">7×7</option>
</select>
<p>Введите значения Матрицы A:</p>
<div class="matrix"></div>
<script>
function oms_mhwA(el) {
var matrix = document.querySelector('.matrix');
matrix.innerHTML = '';
for (var i = 0; i < el; i++) {
for (var k = 0; k < el; k++) {
matrix.innerHTML += '<input type="text" value="0">'
}
matrix.innerHTML += '<br>'
}
}
</script>
<p style="text-align: center;">
<b>A</b>
<input onclick="oms_zakr();" type="button" value="=" title="Найти минимальное покрытие матрицы">
</p>
</div>
|
|
11.12.2017, 19:05
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,108
|
|
riddele_for_you,
function foo(xxx)
{ ....
....
var m = xxx,
....
}
foo(ваша_матрица)
|
|
11.12.2017, 22:22
|
Интересующийся
|
|
Регистрация: 09.12.2017
Сообщений: 12
|
|
Я правильно понял?
function oms_zakra(el) {
function s(a) {
return a.reduce(function (a, b) {
return a + b
}, 0)
}
function c(a) {
return a[0].reduce(function (e, b, g) {
e[g] = [];
for (b = 0; b < a.length; b++) e[g].push(a[b][g]);
return e
}, {})
}
function fn(a, e) {
return Object.keys(a).sort(function (b, g) {
return e ? s(a[g]) - s(a[b]) : s(a[b]) - s(a[g])
})[0]
}
function r(a, e) {
return e.reduce(function (b, e, h) {
e && (b[h] = a[h]);
return b
}, {})
}
function ff(a, e) {
return a.map(function (a) {
return a.filter(function (a, b) {
return 0 == e[b]
})
})
}
function print(a, e, b) {
a = a.reduce(function (a, b) {
return a + "<div>" + JSON.stringify(b) + "</div>"
}, e);
document.body.insertAdjacentHTML("beforeEnd", a + b)
}
var m = el,
temp = "абвгдежзи".split("");
temp.length = m.length;
for (var res = []; 2 < m.length;) {
print(temp, "", "");
print(m, "", "");
var d = c(m),
n = fn(d),
t = d[n],
f = r(m, t),
k = fn(f, !0);
res.push(temp.splice(k, 1)[0]);
var v = m.splice(k, 1)[0];
m = ff(m, v)
}
print([res.sort()], "<b>", "</b>");
}
|
|
11.12.2017, 23:21
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,108
|
|
riddele_for_you,
да
|
|
12.12.2017, 10:14
|
Интересующийся
|
|
Регистрация: 09.12.2017
Сообщений: 12
|
|
Не знаю почему, но программы не работает.
<!DOCTYPE html>
<html>
<head>
<title>Untitled</title>
<meta charset="utf-8">
</head>
<body>
<section class="lib" id="oms_blok1">
<h2 style="text-align: center;">Решение методом Закревского</h2>
<div class="calc" id="frtabl">
Размер матрицы:
<select onchange="oms_mhwA(this.value)">
<option value="2" selected="selected">2×2</option>
<option value="3">3×3</option>
<option value="4">4×4</option>
<option value="5">5×5</option>
<option value="6">6×6</option>
<option value="7">7×7</option>
</select>
<p>Выберете размерность матрицы, после введите значения Матрицы A:</p>
<div class="matrix"></div>
<script>
function oms_mhwA(el) {
var matrix = document.querySelector('.matrix');
matrix.innerHTML = '';
for (var i = 0; i < el; i++) {
for (var k = 0; k < el; k++) {
matrix.innerHTML += '<input type="text" value="0">'
}
matrix.innerHTML += '<br>'
}
}
</script>
<p style="text-align: center;">
<b>A</b>
<input onclick="oms_zakr();" type="button" value="=" title="Найти минимальное покрытие матрицы">
</p>
<script>
function oms_zakr(el) {
function sot(aot) {
return aot.reduce(function (aot, bot) {
return aot + bot
}, 0)
}
function cot(aot) {
return aot[0].reduce(function (eot, bot, got) {
eot[got] = [];
for (bot = 0; bot < aot.length; bot++) eot[got].push(aot[bot][got]);
return eot
}, {})
}
function fnot(aot, eot) {
return Object.keys(aot).sort(function (bot, got) {
return eot ? sot(aot[got]) - sot(aot[bot]) : sot(aot[bot]) - sot(aot[got])
})[0]
}
function rot(aot, eot) {
return eot.reduce(function (bot, eot, hot) {
eot && (bot[hot] = aot[hot]);
return bot
}, {})
}
function ffot(aot, eot) {
return aot.map(function (aot) {
return aot.filter(function (aot, bot) {
return 0 == eot[bot]
})
})
}
function print(aot, eot, bot) {
aot = aot.reduce(function (aot, bot) {
return aot + "<div>" + JSON.stringify(bot) + "</div>"
}, eot);
document.body.insertAdjacentHTML("beforeEnd", aot + bot)
}
var mot = el,
temp = "абвгдежзи".split("");
temp.length = mot.length;
for (var res = []; 2 < mot.length;) {
print(temp, "", "");
print(mot, "", "");
var dot = cot(mot),
not = fnot(dot),
tot = dot[not],
fot = rot(mot, tot),
kot = fnot(fot, !0);
res.push(temp.splice(kot, 1)[0]);
var vot = mot.splice(kot, 1)[0];
mot = ffot(mot, vot)
}
print([res.sort()], "<b>", "</b>");
}
</script>
</div>
</section>
</body>
</html>
|
|
12.12.2017, 10:44
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,108
|
|
где создание массива матрицы?
|
|
12.12.2017, 10:58
|
Интересующийся
|
|
Регистрация: 09.12.2017
Сообщений: 12
|
|
Сообщение от рони
|
где создание массива матрицы?
|
???
var a = new Array()
var a = []
|
|
12.12.2017, 11:04
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,108
|
|
riddele_for_you,
нужен цикл по всем input
|
|
|
|