import java.io.InputStreamReader;
import java.io.BufferedReader;
import java.io.IOException;

public class Main{
    public static void main(String[] args) throws IOException{
        BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
        String str = reader.readLine();
        String[] splits = str.split(" ");
        int n = Integer.parseInt(splits[0]);
        int d = Integer.parseInt(splits[1]);
        str = reader.readLine();
        splits = str.split(" ");
        int[] arr = new int[n];
        int begin = 0, end = 0;
        long res = 0;
        for(; end < n; end++){
            arr[end] = Integer.parseInt(splits[end]);
            if(arr[end] - arr[begin] > d){
                while(arr[end] - arr[begin] > d){
                    res += (long)(end - begin - 1) * (end - begin - 2) / 2;
                    begin++;
                }
            }
        }
        for (; begin <= n-3; begin++) {
            res += (long)(end - begin - 1) * (end - begin - 2) / 2;
        }
        res %= 99997867;
        System.out.println(res);
    }
}