/*
* @Author: hungeazy
* @Date: 2025-10-22 14:30:13
* @Last Modified by: hungeazy
* @Last Modified time: 2025-10-23 15:57:16
*/
#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
// #pragma GCC optimize("O3")
// #pragma GCC optimize("unroll-loops")
// #pragma GCC target("avx2,bmi,bmi2,popcnt,lzcnt")
using namespace std;
using namespace __gnu_pbds;
bool M1;
#define fast ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL);
#define int long long
#define ll long long
#define ull unsigned long long
#define sz(x) x.size()
#define sqr(x) (1LL * (x) * (x))
#define all(x) x.begin(), x.end()
#define fill(f,x) memset(f,x,sizeof(f))
#define FOR(i,l,r) for(int i=l;i<=r;i++)
#define FOD(i,r,l) for(int i=r;i>=l;i--)
#define debug(x) cout << #x << " = " << x << '\n'
#define ii pair<int,int>
#define iii pair<int,ii>
#define di pair<ii,ii>
#define vi vector<int>
#define vii vector<ii>
#define mii map<int,int>
#define fi first
#define se second
#define pb push_back
#define MOD 1000000007
#define __lcm(a,b) (1ll * ((a) / __gcd((a), (b))) * (b))
#define YES cout << "YES\n"
#define NO cout << "NO\n"
#define MASK(i) (1LL << (i))
#define c_bit(i) __builtin_popcountll(i)
#define BIT(x,i) ((x) & MASK(i))
#define SET_ON(x,i) ((x) | MASK(i))
#define SET_OFF(x,i) ((x) & ~MASK(i))
#define oo 1e18
#define name ""
#define endl '\n'
#define memory() cerr << abs(&M2-&M1)/1024.0/1024 << " MB" << endl
#define time() cerr << endl << "-------------Time:" << 1000.0 * clock() / CLOCKS_PER_SEC << "ms." << endl
template<typename T> bool maximize(T &res, const T &val) { if (res < val){ res = val; return true; }; return false; }
template<typename T> bool minimize(T &res, const T &val) { if (res > val){ res = val; return true; }; return false; }
template <class T> using ordered_set = tree <T, null_type, less_equal <T>, rb_tree_tag,tree_order_statistics_node_update>;
const int N = (int)1e5+10;
int n,k,a[N];
namespace sub1 {
bool approved() {
return n <= 100;
}
void solve(void)
{
vi ans;
for (int len = (k%2 == 0?k+1:k); len <= n; len += 2)
{
FOR(i,1,n-len+1)
{
vi vec;
FOR(j,i,i+len-1)
vec.pb(a[j]);
sort(all(vec));
ans.pb(vec[len/2]);
}
}
sort(all(ans));
ans.erase(unique(all(ans)),ans.end());
cout << sz(ans) << endl;
for (int x : ans) cout << x << " ";
}
}
namespace sub4 {
ii b[N];
/*
Xem những thằng a[i] < x là -1, a[i] > x là +1
-> Quy về tìm đoạn con có tổng = 0 và có độ dài >= k và phủ điểm i
-> Cố định phần trái <= j -> phần phải >= j+k-1
-> Tìm các cặp (a,b) thỏa pre[b]-pre[a-1] = 0
Với a thuộc phần trái, b thuộc phần phải
-> Các thằng giá trị ở đây chỉ là -1/1 -> kiểm tra xem 2 đoạn:
[mina,maxa] và [minb,maxb] có giao nhau hay không
-> Segment Lazy + Min max.
*/
struct SegmentTree {
int lazy[N<<2];
struct Node {
int mn,mx;
Node() {mn = oo; mx = -oo;};
Node(int _mn, int _mx):
mn(_mn), mx(_mx) {};
friend Node operator+(Node L, Node R)
{
Node res;
res.mx = max(L.mx,R.mx);
res.mn = min(L.mn,R.mn);
return res;
}
} st[N<<2];
void down(int id)
{
if (!lazy[id]) return;
int &k = lazy[id];
for (int i : {id<<1,id<<1|1})
{
st[i].mx += k;
st[i].mn += k;
lazy[i] += k;
}
k = 0;
}
void updatePos(int id, int l, int r, int pos, int val)
{
if (l == r)
{
st[id] = Node(val,val);
lazy[id] = 0;
return;
}
int mid = (l+r)>>1;
if (pos <= mid) updatePos(id<<1,l,mid,pos,val);
else updatePos(id<<1|1,mid+1,r,pos,val);
st[id] = st[id<<1]+st[id<<1|1];
}
void update(int id, int l, int r, int u, int v, int val)
{
if (l > v or r < u) return;
if (l >= u and r <= v)
{
st[id].mn += val;
st[id].mx += val;
lazy[id] += val;
return;
}
int mid = (l+r)>>1; down(id);
update(id<<1,l,mid,u,v,val);
update(id<<1|1,mid+1,r,u,v,val);
st[id] = st[id<<1]+st[id<<1|1];
}
Node get(int id, int l, int r, int u, int v)
{
if (l > v or r < u) return Node();
if (l >= u and r <= v) return st[id];
int mid = (l+r)>>1; down(id);
return get(id<<1,l,mid,u,v)+get(id<<1|1,mid+1,r,u,v);
}
} IT;
void solve(void)
{
if (k%2 == 0) k++;
FOR(i,1,n) b[i] = {a[i],i};
vi ans;
sort(b+1,b+n+1);
FOR(i,0,n) IT.updatePos(1,0,n,i,-i);
FOR(i,1,n)
{
int pos = b[i].se;
IT.update(1,0,n,pos,n,1);
if (ans.empty() or ans.back() != b[i].fi)
FOR(j,max(1LL,pos-k+1),pos)
{
if (j+k-1 > n) break;
auto left = IT.get(1,0,n,0,j-1), right = IT.get(1,0,n,j+k-1,n);
//pre[j]-pre[i] = 0
if ((left.mn <= right.mn and right.mn <= left.mx) or (right.mn <= left.mn and left.mn <= right.mx))
{
ans.pb(b[i].fi);
break;
}
if (left.mx <= right.mn) j += right.mn-left.mx-1;
else j += left.mn-right.mx-1;
}
IT.update(1,0,n,pos,n,1);
}
cout << sz(ans) << endl;
for (int x : ans) cout << x << " ";
}
}
bool M2;
signed main()
{
fast;
if (fopen(name".inp","r"))
{
freopen(name".inp","r",stdin);
freopen(name".out","w",stdout);
}
cin >> n >> k;
FOR(i,1,n) cin >> a[i];
// if (sub1::approved()) return sub1::solve(), time(), memory(), 0;
sub4::solve();
time();
memory();
return 0;
}
// ██░ ██ █ ██ ███▄ █ ▄████
//▓██░ ██▒ ██ ▓██▒ ██ ▀█ █ ██▒ ▀█▒
//▒██▀▀██░▓██ ▒██░▓██ ▀█ ██▒▒██░▄▄▄░
//░▓█ ░██ ▓▓█ ░██░▓██▒ ▐▌██▒░▓█ ██▓
//░▓█▒░██▓▒▒█████▓ ▒██░ ▓██░░▒▓███▀▒
// ▒ ░░▒░▒░▒▓▒ ▒ ▒ ░ ▒░ ▒ ▒ ░▒ ▒
// ▒ ░▒░ ░░░▒░ ░ ░ ░ ░░ ░ ▒░ ░ ░
// ░ ░░ ░ ░░░ ░ ░ ░ ░ ░ ░ ░ ░
// ░ ░ ░ ░ ░ ░
/*
* @Author: hungeazy
* @Date:   2025-10-22 14:30:13
* @Last Modified by:   hungeazy
* @Last Modified time: 2025-10-23 15:57:16
*/
#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp> 
#include <ext/pb_ds/tree_policy.hpp> 
// #pragma GCC optimize("O3")  
// #pragma GCC optimize("unroll-loops")  
// #pragma GCC target("avx2,bmi,bmi2,popcnt,lzcnt")  
using namespace std;
using namespace __gnu_pbds; 
bool M1;
#define fast ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL);
#define int long long
#define ll long long 
#define ull unsigned long long
#define sz(x) x.size()
#define sqr(x) (1LL * (x) * (x))
#define all(x) x.begin(), x.end()
#define fill(f,x) memset(f,x,sizeof(f))
#define FOR(i,l,r) for(int i=l;i<=r;i++)
#define FOD(i,r,l) for(int i=r;i>=l;i--)
#define debug(x) cout << #x << " = " << x << '\n'
#define ii pair<int,int>
#define iii pair<int,ii>
#define di pair<ii,ii>
#define vi vector<int>
#define vii vector<ii>
#define mii map<int,int>
#define fi first
#define se second
#define pb push_back
#define MOD 1000000007
#define __lcm(a,b) (1ll * ((a) / __gcd((a), (b))) * (b))
#define YES cout << "YES\n"
#define NO cout << "NO\n"
#define MASK(i) (1LL << (i))
#define c_bit(i) __builtin_popcountll(i)
#define BIT(x,i) ((x) & MASK(i))
#define SET_ON(x,i) ((x) | MASK(i))
#define SET_OFF(x,i) ((x) & ~MASK(i))
#define oo 1e18
#define name ""
#define endl '\n'
#define memory() cerr << abs(&M2-&M1)/1024.0/1024 << " MB" << endl
#define time() cerr << endl << "-------------Time:" << 1000.0 * clock() / CLOCKS_PER_SEC << "ms." << endl
template<typename T> bool maximize(T &res, const T &val) { if (res < val){ res = val; return true; }; return false; }
template<typename T> bool minimize(T &res, const T &val) { if (res > val){ res = val; return true; }; return false; }
template <class T> using ordered_set = tree <T, null_type, less_equal <T>, rb_tree_tag,tree_order_statistics_node_update>;
const int N = (int)1e5+10;
int n,k,a[N];

namespace sub1 {

	bool approved() {
		return n <= 100;
	}

	void solve(void)
	{
		vi ans;
		for (int len = (k%2 == 0?k+1:k); len <= n; len += 2)
		{
			FOR(i,1,n-len+1)
			{
				vi vec;
				FOR(j,i,i+len-1)
					vec.pb(a[j]);
				sort(all(vec));
				ans.pb(vec[len/2]);
			}
		}
		sort(all(ans));
		ans.erase(unique(all(ans)),ans.end());
		cout << sz(ans) << endl;
		for (int x : ans) cout << x << " ";
	}
	
}

namespace sub4 {

	ii b[N];
	/*
		Xem những thằng a[i] < x là -1, a[i] > x là +1
		-> Quy về tìm đoạn con có tổng = 0 và có độ dài >= k và phủ điểm i
		-> Cố định phần trái <= j -> phần phải >= j+k-1
		-> Tìm các cặp (a,b) thỏa pre[b]-pre[a-1] = 0
		   Với a thuộc phần trái, b thuộc phần phải 
		-> Các thằng giá trị ở đây chỉ là -1/1 -> kiểm tra xem 2 đoạn:
		[mina,maxa] và [minb,maxb] có giao nhau hay không
		-> Segment Lazy + Min max.
	*/
	struct SegmentTree {
		int lazy[N<<2];

		struct Node {
			int mn,mx;
			Node() {mn = oo; mx = -oo;};
			Node(int _mn, int _mx):
				mn(_mn), mx(_mx) {};
			friend Node operator+(Node L, Node R)
			{
				Node res;
				res.mx = max(L.mx,R.mx);
				res.mn = min(L.mn,R.mn);
				return res;
			}
		} st[N<<2];

		void down(int id)
		{
			if (!lazy[id]) return;
			int &k = lazy[id];
			for (int i : {id<<1,id<<1|1})
			{
				st[i].mx += k;
				st[i].mn += k;
				lazy[i] += k;
			}
			k = 0;
		}

		void updatePos(int id, int l, int r, int pos, int val)
		{
			if (l == r)
			{
				st[id] = Node(val,val);
				lazy[id] = 0;
				return;
			}
			int mid = (l+r)>>1; 
			if (pos <= mid) updatePos(id<<1,l,mid,pos,val);
			else updatePos(id<<1|1,mid+1,r,pos,val);
			st[id] = st[id<<1]+st[id<<1|1];
		}

		void update(int id, int l, int r, int u, int v, int val)
		{
			if (l > v or r < u) return;
			if (l >= u and r <= v)
			{
				st[id].mn += val;
				st[id].mx += val;
				lazy[id] += val;
				return;
			}
			int mid = (l+r)>>1; down(id);
			update(id<<1,l,mid,u,v,val);
			update(id<<1|1,mid+1,r,u,v,val);
			st[id] = st[id<<1]+st[id<<1|1];
		}

		Node get(int id, int l, int r, int u, int v)
		{
			if (l > v or r < u) return Node();
			if (l >= u and r <= v) return st[id];
			int mid = (l+r)>>1; down(id);
			return get(id<<1,l,mid,u,v)+get(id<<1|1,mid+1,r,u,v);
		}
	} IT;

	void solve(void)
	{
		if (k%2 == 0) k++;
		FOR(i,1,n) b[i] = {a[i],i};
		vi ans;
		sort(b+1,b+n+1);
		FOR(i,0,n) IT.updatePos(1,0,n,i,-i);
		FOR(i,1,n)
		{
			int pos = b[i].se;
			IT.update(1,0,n,pos,n,1);
			if (ans.empty() or ans.back() != b[i].fi)
				FOR(j,max(1LL,pos-k+1),pos)
				{
					if (j+k-1 > n) break;
					auto left = IT.get(1,0,n,0,j-1), right = IT.get(1,0,n,j+k-1,n);
					//pre[j]-pre[i] = 0
					if ((left.mn <= right.mn and right.mn <= left.mx) or (right.mn <= left.mn and left.mn <= right.mx))
					{
						ans.pb(b[i].fi);
						break;
					}
					if (left.mx <= right.mn) j += right.mn-left.mx-1;
					else j += left.mn-right.mx-1;
				}
			IT.update(1,0,n,pos,n,1);
		}
		cout << sz(ans) << endl;
		for (int x : ans) cout << x << " ";
	}

}

bool M2;
signed main()
{
    fast;
    if (fopen(name".inp","r"))
    {
    	freopen(name".inp","r",stdin);
    	freopen(name".out","w",stdout);
    }
    cin >> n >> k;
    FOR(i,1,n) cin >> a[i];
    // if (sub1::approved()) return sub1::solve(), time(), memory(), 0;
    sub4::solve();
    time();
    memory();
    return 0;
}
// ██░ ██  █    ██  ███▄    █   ▄████
//▓██░ ██▒ ██  ▓██▒ ██ ▀█   █  ██▒ ▀█▒
//▒██▀▀██░▓██  ▒██░▓██  ▀█ ██▒▒██░▄▄▄░
//░▓█ ░██ ▓▓█  ░██░▓██▒  ▐▌██▒░▓█  ██▓
//░▓█▒░██▓▒▒█████▓ ▒██░   ▓██░░▒▓███▀▒
// ▒ ░░▒░▒░▒▓▒ ▒ ▒ ░ ▒░   ▒ ▒  ░▒   ▒
// ▒ ░▒░ ░░░▒░ ░ ░ ░ ░░   ░ ▒░  ░   ░
// ░  ░░ ░ ░░░ ░ ░    ░   ░ ░ ░ ░   ░
// ░  ░  ░   ░              ░       ░