题解:
给n个数,询问q次,每次询问给出l,r. [l,r]区间求异或最大值为多少?
所以用dp[l][r]来表示区间l,r的答案
先对他进行预处理,预处理后就可以进行dp了。
递推公式:f[i][j]=max(f[i][j],max(f[i+1][j],f[i][j-1]));
/*Keep on going Never give up*/ #pragma GCC optimize(3,"Ofast","inline") #include <iostream> #include <cstdio> #include <stdlib.h> #include <cstring> #include <cmath> #include <math.h> #include <string> #include<string.h> #include <list> #include <set> #include <unordered_map> #include <queue> #include <stack> #include <algorithm> #include <stdlib.h> #include <vector> #include <cctype> #include<iomanip> #define int long long #define endl '\n' using namespace std; const int maxn = 5010; const int MaxN = 0x3f3f3f3f; const int MinN = 0xc0c0c00c; typedef long long ll; const ll mod= 998244353; using namespace std; int f[maxn][maxn],a[maxn]; signed main() { int n,m,l,r; scanf("%lld",&n,&m); for(int i=1;i<=n;i++)scanf("%lld",&a[i]); for(int i=n;i;i--) { for(int j=i;j<=n;j++) { if(i==j)f[i][j]=a[i]; else f[i][j]=f[i+1][j]^f[i][j-1]; } } for(int i=n;i;i--)for(int j=i;j<=n;j++)if(i!=j)f[i][j]=max(f[i][j],max(f[i+1][j],f[i][j-1])); scanf("%lld",&m); for(int i=1;i<=m;i++) { scanf("%lld%lld",&l,&r); printf("%lld\n",f[l][r]); } return 0; }