#include <bits/stdc++.h>
using namespace std;
#define ll long long int
#define endl "\n"
auto random_address = []
{ char *p = new char; delete p; return uint64_t(p); };
const uint64_t SEED = chrono::steady_clock::now().time_since_epoch().count() * (random_address() | 1);
std::mt19937 rnd(SEED);
#define rng(l, r) uniform_int_distribution<int64_t>(l, r)(rnd)
/*
Large Primes for hash
1000000007
10000000019
100000000003
1000000000039
10000000000037
100000000000031
1000000000000037
10000000000000061
2305843009213693951 = (1LL << 61) - 1
*/
constexpr ll mod = 10000000019; // Large prime,
// Takes more time, choose a smaller prime and omit mult64() for faster code but higher probability of collision
// constexpr ll mod = 1e9 + 7; // Is usually sufficient for most of the hashing problems
inline ll mult64(const ll &a, const ll &b)
{
return __int128_t(a) * b % mod;
}
ll modPow(ll N, ll power, ll mod)
{
ll res{1};
while (power)
{
if (power & 1)
res = mult64(res, N);
N = mult64(N, N);
power >>= 1;
}
return res;
}
ll b1 = rng(100, 100000), b2 = rng(1000, 100000);
ll b1I = modPow(b1, mod - 2, mod), b2I = modPow(b2, mod - 2, mod);
vector<ll> Pb1, Pb2, sumB1, sumB2;
void pre(ll maxSize)
{
Pb1 = Pb2 = sumB1 = sumB2 = vector<ll>(maxSize + 1, 1);
for (int i = 1; i <= maxSize; i++)
{
Pb1[i] = mult64(Pb1[i - 1], b1);
Pb2[i] = mult64(Pb2[i - 1], b2);
sumB1[i] = ((sumB1[i - 1] + Pb1[i]) % mod);
sumB2[i] = ((sumB2[i - 1] + Pb2[i]) % mod);
}
}
class Hash
{
using pll = pair<ll, ll>;
ll plus(const ll &x, const ll &y)
{
return ((__int128_t(x) + y + mod) % mod);
}
public:
pll code{};
int size{};
explicit Hash(pair<ll, ll> x = {}, ll sz = {}) : code(std::move(x)), size(sz) {}
Hash(const ll &x) : code({x % mod, x % mod}), size(1) {}
Hash(const string &x) : code(), size(0)
{
for (const char &c : x)
*this = *(this) + c;
}
void pop_front(int x)
{
code.first = (code.first - mult64(Pb1[--size], x) + mod) % mod;
code.second = (code.second - mult64(Pb2[size], x) + mod) % mod;
}
void pop_back(int x)
{
code.first = mult64((code.first - x + mod), b1I);
code.second = mult64((code.second - x + mod), b2I);
size--;
}
void clear()
{
code = {}, size = 0;
}
Hash operator+(const Hash &o)
{
Hash ans;
ans.code = {plus(mult64(code.first, Pb1[o.size]), o.code.first),
plus(mult64(code.second, Pb2[o.size]), o.code.second)};
ans.size = size + o.size;
return ans;
}
friend Hash operator+(const Hash &f, const Hash &o)
{
return Hash({((mult64(f.code.first, Pb1[o.size]) + o.code.first) % mod),
((mult64(f.code.second, Pb2[o.size]) + o.code.second) % mod)},
f.size + o.size);
}
bool operator<(const Hash &o) const
{
if (code == o.code)
return size < o.size;
return code < o.code;
}
bool operator>(const Hash &o) const
{
if (code == o.code)
return size > o.size;
return code > o.code;
}
bool operator>=(const Hash &o) const
{
if (code == o.code)
return (size >= o.size);
return code > o.code;
}
bool operator==(const Hash &o) const
{
return size == o.size && code == o.code;
}
bool operator!=(const Hash &o) const
{
return size != o.size || code != o.code;
}
};
// Rabin-Karp Algorithm
struct HashRange
{
vector<Hash> p, s;
HashRange(const string &t) : p(t.size()), s(t.size())
{
if (t.empty())
return;
p.front() = t.front();
for (int i = 1; i < t.size(); i++)
p[i] = p[i - 1] + t[i];
s.back() = t.back();
for (int i = int(t.size()) - 2; i >= 0; i--)
s[i] = s[i + 1] + t[i];
}
Hash get(int l, int r) const // 0-based indices
{
if (l > r)
return Hash();
if (!l)
return p[r];
return Hash({(p[r].code.first - mult64(p[l - 1].code.first, Pb1[r - l + 1]) + mod) % mod,
(p[r].code.second - mult64(p[l - 1].code.second, Pb2[r - l + 1]) + mod) % mod},
r - l + 1);
}
Hash inv(int l, int r) const // 0-based indices
{
if (l > r)
return Hash();
if (r + 1 == s.size())
return s[l];
return Hash({(s[l].code.first - mult64(s[r + 1].code.first, Pb1[r - l + 1]) + mod) % mod,
(s[l].code.second - mult64(s[r + 1].code.second, Pb2[r - l + 1]) + mod) % mod},
r - l + 1);
}
};
/////////////////////////////////////////////
namespace SuffixArray
{
const int maxN = (1000001);
string S;
int N, gap;
int SA[maxN], pos[maxN], tmp[maxN], lcp[maxN];
bool sufCmp(int i, int j)
{
if (pos[i] != pos[j])
return pos[i] < pos[j];
i += gap;
j += gap;
return (i < N && j < N) ? pos[i] < pos[j] : i > j;
}
void buildSA()
{
N = S.size();
for (int i{}; i < N; i++)
SA[i] = i,
pos[i] = S[i];
for (gap = 1;; gap *= 2)
{
sort(SA, SA + N, sufCmp);
for (int i{}; i < N - 1; i++)
tmp[i + 1] = tmp[i] + sufCmp(SA[i], SA[i + 1]);
for (int i{}; i < N; i++)
pos[SA[i]] = tmp[i];
if (tmp[N - 1] == N - 1)
break;
}
}
void buildLCP()
{
for (int i = 0, k = 0; i < N; ++i)
{
if (pos[i] != N - 1)
{
for (int j = SA[pos[i] + 1]; S[i + k] == S[j + k];)
++k;
lcp[pos[i]] = k;
if (k)
--k;
}
}
}
}
using namespace SuffixArray;
int countSubstrings(const HashRange &H, const Hash &s)
{
// A substring is a prefix of some suffix
int last = S.length(), first = -1;
// Upper bound
{
int L{}, R = S.length();
while (L <= R)
{
int mid = ((L + R) >> 1);
if (H.get(SA[mid], SA[mid] + s.size - 1) > s)
last = mid, R = mid - 1;
else
L = mid + 1;
}
}
// Lower bound
{
int L{}, R = S.length();
while (L <= R)
{
int mid = ((L + R) >> 1);
if (H.get(SA[mid], SA[mid] + s.size - 1) >= s)
first = mid, R = mid - 1;
else
L = mid + 1;
}
}
if (~first)
return last - first;
else
return 0;
}
int main()
{
ios_base::sync_with_stdio(false);
cin.tie(nullptr);
#ifndef ONLINE_JUDGE
freopen("Output.txt", "w", stdout
); #endif //! ONLINE_JUDGE
int t = 1;
ll N, Q;
// cin >> t;
while (t--)
{
cin >> N;
vector<ll> P(N);
for (int i{}; i < N; i++)
cin >> P[i];
string suff("");
for (int i = 1; i < N; i++)
{
if (P[i] > P[i - 1])
suff += "U"; // Up
else if (P[i] < P[i - 1])
suff += "D"; // Down
else
suff += "C"; // Constant
}
S = suff;
S += '#';
buildSA(); // Suffix Array
pre(2000001);
HashRange StrHash = S;
HashRange SuffHash = suff;
cin >> Q;
while (Q--)
{
int X;
cin >> X;
Hash cur = SuffHash.get(N - X, suff.length() - 1);
cout << countSubstrings(StrHash, cur) << endl;
}
}
return 0;
}
#include <bits/stdc++.h>
using namespace std;
#define ll long long int
#define endl "\n"

auto random_address = []
{ char *p = new char; delete p; return uint64_t(p); };
const uint64_t SEED = chrono::steady_clock::now().time_since_epoch().count() * (random_address() | 1);
std::mt19937 rnd(SEED);
#define rng(l, r) uniform_int_distribution<int64_t>(l, r)(rnd)
/*
Large Primes for hash
1000000007
10000000019
100000000003
1000000000039
10000000000037
100000000000031
1000000000000037
10000000000000061
2305843009213693951 = (1LL << 61) - 1
*/
constexpr ll mod = 10000000019; // Large prime,
// Takes more time, choose a smaller prime and omit mult64() for faster code but higher probability of collision
// constexpr ll mod = 1e9 + 7; // Is usually sufficient for most of the hashing problems

inline ll mult64(const ll &a, const ll &b)
{
	return __int128_t(a) * b % mod;
}
ll modPow(ll N, ll power, ll mod)
{
	ll res{1};
	while (power)
	{
		if (power & 1)
			res = mult64(res, N);
		N = mult64(N, N);
		power >>= 1;
	}
	return res;
}
ll b1 = rng(100, 100000), b2 = rng(1000, 100000);
ll b1I = modPow(b1, mod - 2, mod), b2I = modPow(b2, mod - 2, mod);
vector<ll> Pb1, Pb2, sumB1, sumB2;
void pre(ll maxSize)
{
	Pb1 = Pb2 = sumB1 = sumB2 = vector<ll>(maxSize + 1, 1);
	for (int i = 1; i <= maxSize; i++)
	{
		Pb1[i] = mult64(Pb1[i - 1], b1);
		Pb2[i] = mult64(Pb2[i - 1], b2);
		sumB1[i] = ((sumB1[i - 1] + Pb1[i]) % mod);
		sumB2[i] = ((sumB2[i - 1] + Pb2[i]) % mod);
	}
}
class Hash
{
	using pll = pair<ll, ll>;
	ll plus(const ll &x, const ll &y)
	{
		return ((__int128_t(x) + y + mod) % mod);
	}

public:
	pll code{};
	int size{};
	explicit Hash(pair<ll, ll> x = {}, ll sz = {}) : code(std::move(x)), size(sz) {}

	Hash(const ll &x) : code({x % mod, x % mod}), size(1) {}

	Hash(const string &x) : code(), size(0)
	{
		for (const char &c : x)
			*this = *(this) + c;
	}

	void pop_front(int x)
	{
		code.first = (code.first - mult64(Pb1[--size], x) + mod) % mod;
		code.second = (code.second - mult64(Pb2[size], x) + mod) % mod;
	}

	void pop_back(int x)
	{
		code.first = mult64((code.first - x + mod), b1I);
		code.second = mult64((code.second - x + mod), b2I);
		size--;
	}
	void clear()
	{
		code = {}, size = 0;
	}
	Hash operator+(const Hash &o)
	{
		Hash ans;
		ans.code = {plus(mult64(code.first, Pb1[o.size]), o.code.first),
					plus(mult64(code.second, Pb2[o.size]), o.code.second)};
		ans.size = size + o.size;
		return ans;
	}
	friend Hash operator+(const Hash &f, const Hash &o)
	{
		return Hash({((mult64(f.code.first, Pb1[o.size]) + o.code.first) % mod),
					 ((mult64(f.code.second, Pb2[o.size]) + o.code.second) % mod)},
					f.size + o.size);
	}
	bool operator<(const Hash &o) const
	{
		if (code == o.code)
			return size < o.size;
		return code < o.code;
	}
	bool operator>(const Hash &o) const
	{
		if (code == o.code)
			return size > o.size;
		return code > o.code;
	}
	bool operator>=(const Hash &o) const
	{
		if (code == o.code)
			return (size >= o.size);
		return code > o.code;
	}
	bool operator==(const Hash &o) const
	{
		return size == o.size && code == o.code;
	}
	bool operator!=(const Hash &o) const
	{
		return size != o.size || code != o.code;
	}
};

// Rabin-Karp Algorithm
struct HashRange
{
	vector<Hash> p, s;
	HashRange(const string &t) : p(t.size()), s(t.size())
	{
		if (t.empty())
			return;
		p.front() = t.front();
		for (int i = 1; i < t.size(); i++)
			p[i] = p[i - 1] + t[i];
		s.back() = t.back();
		for (int i = int(t.size()) - 2; i >= 0; i--)
			s[i] = s[i + 1] + t[i];
	}
	Hash get(int l, int r) const // 0-based indices
	{
		if (l > r)
			return Hash();
		if (!l)
			return p[r];
		return Hash({(p[r].code.first - mult64(p[l - 1].code.first, Pb1[r - l + 1]) + mod) % mod,
					 (p[r].code.second - mult64(p[l - 1].code.second, Pb2[r - l + 1]) + mod) % mod},
					r - l + 1);
	}
	Hash inv(int l, int r) const // 0-based indices
	{
		if (l > r)
			return Hash();
		if (r + 1 == s.size())
			return s[l];
		return Hash({(s[l].code.first - mult64(s[r + 1].code.first, Pb1[r - l + 1]) + mod) % mod,
					 (s[l].code.second - mult64(s[r + 1].code.second, Pb2[r - l + 1]) + mod) % mod},
					r - l + 1);
	}
};
/////////////////////////////////////////////

namespace SuffixArray
{
	const int maxN = (1000001);
	string S;
	int N, gap;
	int SA[maxN], pos[maxN], tmp[maxN], lcp[maxN];

	bool sufCmp(int i, int j)
	{
		if (pos[i] != pos[j])
			return pos[i] < pos[j];
		i += gap;
		j += gap;
		return (i < N && j < N) ? pos[i] < pos[j] : i > j;
	}

	void buildSA()
	{
		N = S.size();
		for (int i{}; i < N; i++)
			SA[i] = i,
			pos[i] = S[i];
		for (gap = 1;; gap *= 2)
		{
			sort(SA, SA + N, sufCmp);
			for (int i{}; i < N - 1; i++)
				tmp[i + 1] = tmp[i] + sufCmp(SA[i], SA[i + 1]);
			for (int i{}; i < N; i++)
				pos[SA[i]] = tmp[i];
			if (tmp[N - 1] == N - 1)
				break;
		}
	}

	void buildLCP()
	{
		for (int i = 0, k = 0; i < N; ++i)
		{
			if (pos[i] != N - 1)
			{
				for (int j = SA[pos[i] + 1]; S[i + k] == S[j + k];)
					++k;
				lcp[pos[i]] = k;
				if (k)
					--k;
			}
		}
	}
}
using namespace SuffixArray;

int countSubstrings(const HashRange &H, const Hash &s)
{
	// A substring is a prefix of some suffix
	int last = S.length(), first = -1;
	// Upper bound
	{
		int L{}, R = S.length();
		while (L <= R)
		{
			int mid = ((L + R) >> 1);
			if (H.get(SA[mid], SA[mid] + s.size - 1) > s)
				last = mid, R = mid - 1;
			else
				L = mid + 1;
		}
	}
	// Lower bound
	{
		int L{}, R = S.length();
		while (L <= R)
		{
			int mid = ((L + R) >> 1);
			if (H.get(SA[mid], SA[mid] + s.size - 1) >= s)
				first = mid, R = mid - 1;
			else
				L = mid + 1;
		}
	}
	if (~first)
		return last - first;
	else
		return 0;
}

int main()
{
	ios_base::sync_with_stdio(false);
	cin.tie(nullptr);
#ifndef ONLINE_JUDGE
	freopen("input.txt", "r", stdin);
	freopen("Output.txt", "w", stdout);
#endif //! ONLINE_JUDGE
	int t = 1;
	ll N, Q;
	// cin >> t;
	while (t--)
	{
		cin >> N;
		vector<ll> P(N);
		for (int i{}; i < N; i++)
			cin >> P[i];

		string suff("");
		for (int i = 1; i < N; i++)
		{
			if (P[i] > P[i - 1])
				suff += "U"; // Up
			else if (P[i] < P[i - 1])
				suff += "D"; // Down
			else
				suff += "C"; // Constant
		}
		S = suff;
		S += '#';
		buildSA(); // Suffix Array
		pre(2000001);
		HashRange StrHash = S;
		HashRange SuffHash = suff;
		cin >> Q;
		while (Q--)
		{
			int X;
			cin >> X;
			Hash cur = SuffHash.get(N - X, suff.length() - 1);
			cout << countSubstrings(StrHash, cur) << endl;
		}
	}
	return 0;
}