Submission #1381332


Source Code Expand

using System.Collections.Generic;
using System.Linq;
using System;
class Z { static void Main() { new K(); } }
class K
{
	public const int INF = 1000000007;
	int V, R, T, C;
	readonly List<E>[] es;
	long s;
	public K()
	{
		var I = G();
		V = I[0];
		int E = I[1];
		R = I[2];
		T = I[3];
		es = new List<E>[V];
		var deg = new int[V];
		for (var i = 0; i < V; i++) es[i] = new List<E>();
		for (var e = 0; e < E; e++)
		{
			I = G();
			AddEdge(I[0] - 1, I[1] - 1, I[2]);
		}
		for (var u = 0; u < V; u++) Calc(DijkstraFrom(u));
		Console.WriteLine(s);
	}
	void Calc(int[] d)
	{
		Array.Sort(d);
		var i = 1;
		for (var x = 1; x < V; x++)
		{
			var t = R * d[x] / T;
			while (i < V && t >= d[i]) i++;
			if (i == V) return;
			s += V - i;
			if (i <= x) s--;
		}
	}
	void AddEdge(int f, int t, int c)
	{
		es[f].Add(new E(t, c));
		es[t].Add(new E(f, c));
		C = Math.Max(C, c);
	}
	int[] DijkstraFrom(int from)
	{
		var d = new int[V];
		for (var i = 0; i < V; i++) d[i] = INF;
		var queue = new DialQueue(C);
		d[from] = 0;
		queue.Add(from, 0);
		while (queue.Any)
		{
			var p = queue.Pop();
			var v = p.To;
			if (d[v] < p.Cost) continue;
			foreach (var e in es[v])
			{
				var tmp = d[v] + e.Cost;
				if (d[e.To] > tmp)
				{
					if (d[e.To] != INF) queue.Move(e.To, d[e.To], tmp);
					else queue.Add(e.To, tmp);
					d[e.To] = tmp;
				}
			}
		}
		return d;
	}
	static List<int> G()
	{
		var line = Console.ReadLine();
		var ans = new List<int>();
		var n = 0;
		foreach (var c in line)
		{
			if (c == ' ')
			{
				ans.Add(n);
				n = 0;
			}
			else n = 10 * n + (c - '0');
		}
		ans.Add(n);
		return ans;
	}
}
struct E
{
	public readonly int To, Cost;
	public E(int t, int c)
	{
		To = t;
		Cost = c;
	}
}
class DialQueue
{
	public int Count { get; private set; }
	readonly int C;
	int offset;
	readonly HashSet<int>[] buckets;
	HashSet<int> this[int n] { get { return buckets[(n - offset + offset % C) % C]; } }
	public DialQueue(int c)
	{
		C = c + 1;
		buckets = new HashSet<int>[C];
		for (var i = 0; i < C; i++) buckets[i] = new HashSet<int>();
	}
	public void Add(int v, int d)
	{
		Count++;
		this[d].Add(v);
	}
	public void Move(int v, int prev, int now)
	{
		this[prev].Remove(v);
		this[now].Add(v);
	}
	public bool Any { get { return Count > 0; } }
	public E Pop()
	{
		Count--;
		var t = offset;
		while (true)
		{
			var s = this[t];
			if (s.Count > 0)
			{
				var v = s.First();
				s.Remove(v);
				return new E(v, offset = t);
			}
			t++;
		}
	}
}

Submission Info

Submission Time
Task C - ウサギとカメ
User selpo
Language C# (Mono 4.6.2.0)
Score 100
Code Size 2627 Byte
Status AC
Exec Time 3005 ms
Memory 38416 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 100 / 100
Status
AC × 2
AC × 18
Set Name Test Cases
Sample subtask0_sample-01.txt, subtask0_sample-02.txt
All subtask0_sample-01.txt, subtask0_sample-02.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
Case Name Status Exec Time Memory
subtask0_sample-01.txt AC 29 ms 11484 KB
subtask0_sample-02.txt AC 28 ms 11476 KB
subtask1_01.txt AC 29 ms 11476 KB
subtask1_02.txt AC 28 ms 9436 KB
subtask1_03.txt AC 29 ms 11476 KB
subtask1_04.txt AC 28 ms 11476 KB
subtask1_05.txt AC 42 ms 13524 KB
subtask1_06.txt AC 45 ms 11476 KB
subtask1_07.txt AC 90 ms 15820 KB
subtask1_08.txt AC 110 ms 17736 KB
subtask1_09.txt AC 833 ms 16576 KB
subtask1_10.txt AC 792 ms 20420 KB
subtask1_11.txt AC 341 ms 13856 KB
subtask1_12.txt AC 2615 ms 32676 KB
subtask1_13.txt AC 2567 ms 36648 KB
subtask1_14.txt AC 2970 ms 38416 KB
subtask1_15.txt AC 1986 ms 33788 KB
subtask1_16.txt AC 3005 ms 36364 KB