Submission #4779332


Source Code Expand

'use strict'

class Main {
  solve() {
    const nm = input.nextIntArr();
    const uvs = input.nextIntRange(nm[1]).map(l => l.map(e=>e-1));
    const loop = new Unit('loop');
    loop.init = () => false;
    loop.union = (x,y,rmin,rmax) => {
      loop.data[rmin] = 
        (loop.data[rmin] || loop.data[rmax] || rmin == rmax);
    }
    const uf = new UnionFind(nm[0],[loop]);
    for (const uv of uvs) { const root = uf.unite(uv[0],uv[1]); }
    return uf.getData('ref').filter((e,i) => e == i && !uf.get('loop',i))
.length;
  }
}

class Unit {
  constructor(name) { this.name = name; this.data = []; }
  get(rx) { return this.data[rx]; }
  set(x,value) { this.data[x] = value; return this.data[x]; }
  set init(func) { this._init = func; }
  set union(func) { this._union = func; }
  get init() { return this._init; }
  get union() { return this._union }
}

class UnionFind {
  constructor(n, options) {
    if (options == null) { options = []; }
    this.units = {};
    this.units['ref'] = UnionFind._ref;
    for (const o of options) {
      if (o === 'count') { this.units['count'] = UnionFind.Counter; }
      else if (o instanceof Unit) { this.units[o.name] = o; }
    }
    for (const name in this.units) {
      const unit = this.units[name];
      for (let i = 0;i < n; ++i) { unit.init(i); }
    }
  }

  root(x) {
    if (this.units.ref.get(x) == x) return x;
    return this.units.ref.set(x, this.root(this.units.ref.get(x)));
  }

  getData(name) { return this.units[name].data; }
  get(name, x) {
    return this.units[name].get(this.root(x));
  }
  size(x) { return this.get('count', x); }

  unite(x, y) { // xとyの木を併合
    const rx = this.root(x); const ry = this.root(y);
    const rmax = Math.max(rx,ry); const rmin = Math.min(rx,ry);
    for (const name in this.units) { 
      const u = this.units[name];
      u.union(x,y,rmin,rmax); 
    }
    return true;
  }

  same(x, y) { // 2つのデータx, yが属する木が同じならtrueを返す
    const rx = this.root(x);
    const ry = this.root(y);
    return rx == ry;
  } 

  static get _ref() {
    const u = new Unit('ref');
    u.init = ((i) => u.data[i] = i);
    u.union = ((x,y,rmin,rmax) => {
      if (rmax == rmin) return;
      u.data[rmax] = rmin;
    });
    return u;
  }

  static get Counter() {
    const u = new Unit('count');
    u.init = ((i) => u.data[i] = 1);
    u.union = ((x,y,rmin,rmax) => {
      if (rmax == rmin) return;
      u.data[rmin] = u.data[rmax] + u.data[rmin];
    });
    return u;
  }
} 

class Mod {
  constructor(mod) {
    if (mod == null) { mod = Combinatorics.DefaultMod; }
    this.mod = mod;
  }

  mult(a,b) {
    let ret = 0;
    a %= this.mod;
    b %= this.mod;
    while (b) {
      if (b&1) {
        ret += a;
        if (ret > this.mod) { ret -= this.mod; }
      }
      a <<= 1;
      if (a > this.mod) { a -= this.mod; }
      b >>= 1;
    }
    return ret;
  }

  pow(a,b) {
    let ret = 1;
    while(b) {
      if (b&1) { ret = this.mult(ret,a); }
      a = this.mult(a,a);
      b >>= 1;
    }
    return ret;
  }
}
const MOD = new Mod(1e9+7);

class Underscore {
  sum(arr) { return arr.reduce((a,b)=>a+b); }
  modSum(arr,mod) { if (mod == null) { mod = MOD.mod; } return arr.reduce((a,b)=>(a+b)%mod); }
  min(arr, func) { if (func == null) {func = (a,b) => a - b} return arr.reduce((a,b) => func(a,b) < 0 ? a : b); }
  max(arr, func) { if (func == null) {func = (a,b) => a - b} return arr.reduce((a,b) => func(a,b) > 0 ? a : b); }
  sort(arr, func) { if (func == null) {func = (a,b) => a - b} return arr.sort(func) }
  uniq(arr) { 
    arr.sort();
    for(let i = 0; i < arr.length - 1; ++i) { 
      arr[i] = arr[i+1] == arr[i] ? null : arr[i]; 
    }
    return arr.filter(e => e != null);
  }
  range(start, stop, step) {
    if (stop == null) { stop = start || 0; start = 0; }
    if (!step) { step = stop < start ? -1 : 1; }
    const length = Math.max(Math.ceil((stop - start) / step), 0);
    const range = Array(length);
    for (var idx = 0; idx < length; idx++, start += step) { range[idx] = start; }
    return range;
  }
  first (array, n) {
    if (array == null || array.length < 1) return n == null ? void 0 : [];
    if (n == null) return array[0];
    return this.initial(array, array.length - n);
  };
  initial (array, n) { return array.slice.call(array, 0, Math.max(0, array.length - (n == null ? 1 : n))); }
  tail(array, n) { return array.slice.call(array, n == null ? 1 : n); }
  last (array, n) { if (n == null) return array[array.length - 1]; return this.tail(array, Math.max(0, array.length - n)); }
  sumArray (arr) { return this.tail(arr.reduce(((a,b,i) => {a.push(b + a[i]); return a}), [0])); }
  diffArray (arr) { const s = []; for (let i = 1; i < arr.length; ++i) { s.push(arr[i] - arr[i-1]); } return s; }
  binarySearch (array, key, iteratee) {
    const itr = (obj) => (typeof obj === 'object') ? obj[iteratee] : obj;
    const value = itr(key);
    let low = 0, high = array.length;
    while (low < high) {
      let mid = Math.floor((low + high) / 2);
      if (itr(array[mid]) < value) low = mid + 1; else high = mid;
    }
    return low;
  };
}
const _ = new Underscore();

class Input {
  constructor() {
    this.cursor = 0;
    this.inputAll();
  }

  inputAll() {
    this.data = (require("fs").readFileSync("/dev/stdin", "utf8")).split('\n');
    return this.data;
  }

  /* 1行 or 複数行文字列 */
  nextLine(n) {
    if (n) {
      const ret = this.data.slice(this.cursor, this.cursor + n);
      this.cursor += n;
      return ret;
    }
    return this.data[this.cursor++];
  }
  /* 1整数 */
  nextInt() { return parseInt(this.nextLine()); } 
  /* 一行文字配列 */
  nextStrArr() { return this.nextLine().split(' '); } 
  /* 一行整数配列 */
  nextIntArr() { return this.nextStrArr().map((e) => parseInt(e)); }
  /* 一行浮動小数点配列 */
  nextFloatArr() { return this.nextStrArr().map((e) => parseFloat(e)); }
  /* 複数行整数配列 */
  nextIntLine(n) { return this.nextLine(n).map((e) => parseInt(e)) }
  /* 複数行浮動小数点配列 */
  nextFloatLine(n) { return this.nextLine(n).map((e) => parseFloat(e)) }
  /* 複数行文字列二次元配列 */
  nextStrRange(n) { return this.nextLine(n).map((line) => line.split(' ')); }
  /* 複数行整数二次元配列 */
  nextIntRange(n) {
    return this.nextLine(n).map((line) => line.split(' ').map((e) => parseInt(e)));
  }
  /* 複数行浮動小数点数二次元配列 */
  nextFloatRange(n) {
    return this.nextLine(n).map((line) => line.split(' ').map((e) => parseFloat(e)));
  }
} 
const input = new Input();

const Out = (output) => {
  let ret;
  if (output == null) return;
  if (output === true) { ret = 'Yes'; }
  else if (output === false) { ret = 'No'; }
  else { ret = output; }
  console.log(ret);
}

Out(new Main().solve());

Submission Info

Submission Time
Task B - バウムテスト
User wand125
Language JavaScript (node.js v5.12)
Score 100
Code Size 6842 Byte
Status AC
Exec Time 71 ms
Memory 10780 KiB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 100 / 100
Status
AC × 3
AC × 34
Set Name Test Cases
Sample subtask0_sample_01.txt, subtask0_sample_02.txt, subtask0_sample_03.txt
All subtask0_sample_01.txt, subtask0_sample_02.txt, subtask0_sample_03.txt, subtask1_01.txt, subtask1_02.txt, subtask1_03.txt, subtask1_04.txt, subtask1_05.txt, subtask1_06.txt, subtask1_07.txt, subtask1_08.txt, subtask1_09.txt, subtask1_10.txt, subtask1_11.txt, subtask1_12.txt, subtask1_13.txt, subtask1_14.txt, subtask1_15.txt, subtask1_16.txt, subtask1_17.txt, subtask1_18.txt, subtask1_19.txt, subtask1_20.txt, subtask1_21.txt, subtask1_22.txt, subtask1_23.txt, subtask1_24.txt, subtask1_25.txt, subtask1_26.txt, subtask1_27.txt, subtask1_28.txt, subtask1_29.txt, subtask1_30.txt, subtask1_31.txt
Case Name Status Exec Time Memory
subtask0_sample_01.txt AC 55 ms 7372 KiB
subtask0_sample_02.txt AC 55 ms 7372 KiB
subtask0_sample_03.txt AC 55 ms 7372 KiB
subtask1_01.txt AC 55 ms 7372 KiB
subtask1_02.txt AC 55 ms 7372 KiB
subtask1_03.txt AC 55 ms 7372 KiB
subtask1_04.txt AC 58 ms 7756 KiB
subtask1_05.txt AC 55 ms 7372 KiB
subtask1_06.txt AC 55 ms 7372 KiB
subtask1_07.txt AC 55 ms 7372 KiB
subtask1_08.txt AC 56 ms 7500 KiB
subtask1_09.txt AC 56 ms 7500 KiB
subtask1_10.txt AC 55 ms 7372 KiB
subtask1_11.txt AC 55 ms 7372 KiB
subtask1_12.txt AC 55 ms 7372 KiB
subtask1_13.txt AC 58 ms 7756 KiB
subtask1_14.txt AC 55 ms 7500 KiB
subtask1_15.txt AC 57 ms 7756 KiB
subtask1_16.txt AC 58 ms 7756 KiB
subtask1_17.txt AC 57 ms 7756 KiB
subtask1_18.txt AC 56 ms 7756 KiB
subtask1_19.txt AC 57 ms 7756 KiB
subtask1_20.txt AC 55 ms 7372 KiB
subtask1_21.txt AC 58 ms 7756 KiB
subtask1_22.txt AC 55 ms 7372 KiB
subtask1_23.txt AC 56 ms 7756 KiB
subtask1_24.txt AC 56 ms 7628 KiB
subtask1_25.txt AC 54 ms 7372 KiB
subtask1_26.txt AC 56 ms 7628 KiB
subtask1_27.txt AC 56 ms 7628 KiB
subtask1_28.txt AC 56 ms 7628 KiB
subtask1_29.txt AC 71 ms 10652 KiB
subtask1_30.txt AC 71 ms 10780 KiB
subtask1_31.txt AC 55 ms 7372 KiB