import java.awt.Point;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.math.BigInteger;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.HashMap;
import java.util.LinkedList;
import java.util.Scanner;
import java.util.Stack;
import java.util.StringTokenizer;
class TestClass {
static long[] dis ;
static int[] vis;
static ArrayList<Integer>[] resu;
static int[] som;
static long max;
static long max2;
static int[][] dp;
public static void update(int[] som , int i, int value){
while(i<=100000){
som[i]+=value;
i+=(i&-i);
}
}
public static int value(int[] som , int i){
int ans =0;
while(i>0)
{
ans+=som[i];
i-=(i&-i);
}
return ans;
}
// BufferedReader in = new BufferedReader(new FileReader("C:\\Users\\Sompathak\\Desktop\\yes.txt"));
// Scanner in = new Scanner(new FileReader("C:\\Users\\Sompathak\\Desktop\\yes.txt"));
// PrintWriter pw = new PrintWriter(new FileWriter("C:\\Users\\Sompathak\\Desktop\\output.txt"));
//Scanner in = new Scanner(new FileReader("C:\\Users\\Sompathak\\Desktop\\yes.txt"));
int n = in.nextInt();
int k =in.nextInt();
int[] a = new int[n];
for(int i=0;i<n;i++) a[i]=in.nextInt();
som = new int[100001];
dp = new int[n+1][k+1];
for(int i=0;i<n;i++) dp[i][1]=1;
for(int i=2;i<=k;i++){
som = new int[100001];
for(int j=1;j<n;j++){
int xx = dp[j-1][i-1];
if(xx!=0)
update(som,a[j-1],xx);
dp[j][i] = value(som,a[j]-1);
}
}
int ans =0;
for(int i=0;i<n;i++) ans+=dp[i][k];
}
}