1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- const Moon = require("./Moon");
- const Vector3 = require("./Vector3");
- function parseInput(inputs) {
- const moons = [];
- const parseRegex = new RegExp(/x=(-?\d+), y=(-?\d+), z=(-?\d+)/);
- for (const position of inputs) {
-
- const [undefined, x, y, z] = position.match(parseRegex);
- moons.push(new Moon(new Vector3(parseInt(x, 10), parseInt(y, 10), parseInt(z, 10))));
- }
- return moons;
- }
- function step(moons) {
- for (let i = 0; i < moons.length - 1; i++) {
- for (let j = i + 1; j < moons.length; j++) {
-
- const firstGravity = calculateGravity(moons[i], moons[j]);
-
- const secondGravity = firstGravity.negate();
- moons[i].velocity.add(firstGravity);
- moons[j].velocity.add(secondGravity);
- }
- }
- moons.forEach((moon) => { moon.position.add(moon.velocity); });
- }
- function calculateGravity(moonA, moonB) {
-
- const gravityDifference = new Vector3(
-
- moonB.position.x > moonA.position.x ? 1 : (moonB.position.x < moonA.position.x ? -1 : 0),
-
- moonB.position.y > moonA.position.y ? 1 : (moonB.position.y < moonA.position.y ? -1 : 0),
-
- moonB.position.z > moonA.position.z ? 1 : (moonB.position.z < moonA.position.z ? -1 : 0),
- );
- return gravityDifference;
- }
- module.exports = {
- parseInput,
- step,
- };
|