4.2 KiB
4.2 KiB
id | title | challengeType | videoUrl | localeTitle |
---|---|---|---|---|
587d8256367417b2b2512c79 | Incidence Matrix | 1 | Matriz de Incidência |
Description
1Aqui está um exemplo de uma
---
1 | 1
2 | 0
3 | 1
incidence matrix
com 4 arestas e 4 nós. Lembre-se, as colunas são as arestas e as linhas são os próprios nós. 1 2 3 4Abaixo está uma implementação JavaScript da mesma coisa.
--------
1 | 0 1 1 1
2 | 1 1 0 0
3 | 1 0 0 1
4 | 0 0 1 0
var incMat = [Para fazer um gráfico direcionado, use
[0, 1, 1, 1],
[1, 1, 0, 0],
[1, 0, 0, 1]
[0, 0, 1, 0]
];
-1
para uma aresta deixando um determinado nó e 1
para uma aresta entrando em um nó. var incMatDirected = [Gráficos também podem ter pesos em suas bordas. Até agora, temos arestas não ponderadas onde apenas a presença e a falta de aresta é binária (
[0, -1, 1, -1]
[-1, 1, 0, 0],
[1, 0, 0, 1]
[0, 0, -1, 0]
];
0
ou 1
). Você pode ter pesos diferentes dependendo do seu aplicativo. Um peso diferente é representado como números maiores que 1. Instructions
Tests
tests:
- text: <code>incMatUndirected</code> deve conter apenas cinco nós.
testString: 'assert((incMatUndirected.length === 5) && incMatUndirected.map(function(x) { return x.length === 4 }).reduce(function(a, b) { return a && b }) , "<code>incMatUndirected</code> should only contain five nodes.");'
- text: Deve haver uma primeira borda entre o primeiro e o segundo nó.
testString: 'assert((incMatUndirected[0][0] === 1) && (incMatUndirected[1][0] === 1), "There should be a first edge between the first and second node.");'
- text: Deve haver uma segunda borda entre o segundo e o terceiro nó.
testString: 'assert((incMatUndirected[1][1] === 1) && (incMatUndirected[2][1] === 1), "There should be a second edge between the second and third node.");'
- text: Deve haver uma terceira borda entre o terceiro e o quinto nó.
testString: 'assert((incMatUndirected[2][2] === 1) && (incMatUndirected[4][2] === 1), "There should be a third edge between the third and fifth node.");'
- text: Deve haver uma quarta borda entre o segundo e o quarto nó.
testString: 'assert((incMatUndirected[1][3] === 1) && (incMatUndirected[3][3] === 1), "There should be a fourth edge between the second and fourth node.");'
Challenge Seed
var incMatUndirected = [
];
Solution
// solution required