首页 > 其他分享 >Lydsy八月份月赛

Lydsy八月份月赛

时间:2022-10-24 16:39:26浏览次数:40  
标签:月赛 Lydsy ch return 八月份 int ll long define


BZOJ 4971 记忆中的背包

#include<bits/stdc++.h>
using namespace std;
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
For(j,m-1) cout<<a[i][j]<<' ';\
cout<<a[i][m]<<endl; \
}
typedef long long ll;
typedef unsigned long long ull;
ll mul(ll a,ll b){return (a*b)%F;}
ll add(ll a,ll b){return (a+b)%F;}
ll sub(ll a,ll b){return (a-b+llabs(a-b)/F*F+F)%F;}
void upd(ll &a,ll b){a=(a%F+b%F)%F;}
int read()
{
int x=0,f=1; char ch=getchar();
while(!isdigit(ch)) {if (ch=='-') f=-1; ch=getchar();}
while(isdigit(ch)) { x=x*10+ch-'0'; ch=getchar();}
return x*f;
}
#define
ll C[40][40];
ll g[MAXN][40];
ll p[MAXN][40];
ll f[MAXN][40]; //w ,c(I,>)
void prework() {
int n=30;
C[0][0]=1;
For(i,n) {
C[i][0]=1;
For(j,i) {
C[i][j]=(C[i-1][j-1]+C[i-1][j]);
}
}
MEMI(f)
ForD(i,30) {
f[0][i]=0;
For(j,20000) Rep(x,(i+1)/2+1) if (j>=C[i][x]){
if (f[j][i]> f[j-C[i][x]][i] + 1 ) {
f[j][i]=f[j-C[i][x]][i] + 1;
g[j][i]=j-C[i][x];
p[j][i]=x;
}
}
}
}
ll w,mo,k;
int ans[MAXN];
void work() {
if (!k) {
puts("1");
cout<<w-1<<endl;
}else if (k<=40) {
cout<<k<<endl;
For(i,k-1) cout<<w<<' ';cout<<w<<endl;
}else {

For(i,30) {
if (f[k][i]+i<=40) {
printf("%d\n",f[k][i]+i);
int cnt=0;
while(k) {
ans[++cnt]=w-p[k][i] ;
k=g[k][i];
}
while(i--) ans[++cnt]=1;
PRi(ans,cnt);
return;
}
}
}
}
int main()
{
// freopen("bzoj4971.in","r",stdin);
// freopen(".out","w",stdout);
int T=read();
prework();
while(T--) {
scanf("%lld%lld%lld",&w,&mo,&k);
work();
}


return 0;
}

BZOJ 4972 小Q的方格纸

#include<bits/stdc++.h>
using namespace std;
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
For(j,m-1) cout<<a[i][j]<<' ';\
cout<<a[i][m]<<endl; \
}
#pragma
typedef long long ll;
typedef long double ld;
typedef unsigned long long ull;
typedef unsigned int uint;
ll mul(ll a,ll b){return (a*b)%F;}
ll add(ll a,ll b){return (a+b)%F;}
ll sub(ll a,ll b){return ((a-b)%F+F)%F;}
void upd(ll &a,ll b){a=(a%F+b%F)%F;}
int read()
{
int x=0,f=1; char ch=getchar();
while(!isdigit(ch)) {if (ch=='-') f=-1; ch=getchar();}
while(isdigit(ch)) { x=x*10+ch-'0'; ch=getchar();}
return x*f;
}
#define
int n,m,q;
unsigned int A,B,C;
uint a[MAXN][MAXN];
inline unsigned int rng61(){
A ^= A << 16;
A ^= A >> 5;
A ^= A << 1;
unsigned int t = A;
A = B;
B = C;
C ^= t ^ A;
return C;
}
uint s[MAXN][MAXN];
uint t[MAXN][MAXN];
void prework() {
MEM(s) MEM(t)
For(i,n) For(j,m) s[i][j]=s[i][j-1]+s[i-1][j]-s[i-1][j-1]+a[i][j];
For(i,n) For(j,m) {
t[i][j]=t[i-1][j]+a[i][j];
}
For(i,n) ForD(j,m) {
t[i][j]+=t[i-1][j+1];
}
}
uint calc(int x,int y,int k) {
uint p=s[x][y] - s[x][y-k] ;
uint l=t[x-1][y-k+1]-t[x-k-1][y+1];
return p-l;
}
uint f[3000000+10];
int main()
{
// freopen("B.in","r",stdin);
// freopen(".out","w",stdout);
int i,j;
uint x,y,k;
scanf("%d%d%d%u%u%u", &n, &m, &q, &A, &B, &C);
for(i = 1; i <= n; i++)
for(j = 1; j <= m; j++)
a[i][j] = rng61();
// PRi2D(a,n,m)
prework();
// cout<<a[3][2]+a[3][1]+a[2][2];
for(i = 1; i <= q; i++){
x = rng61() % n + 1;
y = rng61() % m + 1;
k = rng61() % min(x, y) + 1;
// cout<<x<<' '<<y<<' '<<k<<endl;
f[i]=calc(x,y,k);
// cout<<f[i]<<endl;
}
uint p=1,ans=0;
ForD(i,q) {
ans+=p*f[i];
p*=(uint)233;
}
printf("%u\n",ans);


return 0;
}

BZOJ 4974 字符串大师

#include<bits/stdc++.h>
using namespace std;
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
For(j,m-1) cout<<a[i][j]<<' ';\
cout<<a[i][m]<<endl; \
}
#pragma
#define
typedef long long ll;
typedef long double ld;
typedef unsigned long long ull;
ll mul(ll a,ll b){return (a*b)%F;}
ll add(ll a,ll b){return (a+b)%F;}
ll sub(ll a,ll b){return ((a-b)%F+F)%F;}
void upd(ll &a,ll b){a=(a%F+b%F)%F;}
int read()
{
int x=0,f=1; char ch=getchar();
while(!isdigit(ch)) {if (ch=='-') f=-1; ch=getchar();}
while(isdigit(ch)) { x=x*10+ch-'0'; ch=getchar();}
return x*f;
}
#define
bool b[26];
char s[MAXN];
int f[MAXN];
int main()
{
// freopen("D.in","r",stdin);
// freopen(".out","w",stdout);
int n=read();
For(i,n) f[i]=read();
f[0]=0; int p=0;
For(i,n) {
if (i==1) s[i]='a';
else if (f[i]!=i) {
s[i]=s[i- f[i] ];
}
else {
int p=i-1;
p-=f[p];
MEM(b)
while(p) {
b[s[p+1]-'a']=1;
p-=f[p];
}
b[s[p+1]-'a']=1;
Rep(j,26) {
if (!b[j]) {
s[i]=j+'a';
break;
}
}
}
}
printf("%s",s+1);
return 0;
}

BZOJ 4975 区间翻转

#include<bits/stdc++.h> 
using namespace std;
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
For(j,m-1) cout<<a[i][j]<<' ';\
cout<<a[i][m]<<endl; \
}
#pragma
#define
typedef long long ll;
typedef long double ld;
typedef unsigned long long ull;
ll mul(ll a,ll b){return (a*b)%F;}
ll add(ll a,ll b){return (a+b)%F;}
ll sub(ll a,ll b){return ((a-b)%F+F)%F;}
void upd(ll &a,ll b){a=(a%F+b%F)%F;}
inline int read()
{
int x=0,f=1; char ch=getchar();
while(!isdigit(ch)) {if (ch=='-') f=-1; ch=getchar();}
while(isdigit(ch)) { x=x*10+ch-'0'; ch=getchar();}
return x*f;
}
int a[1234];
int main()
{
// freopen("bzoj4975.in","r",stdin);
// freopen(".out","w",stdout);
int n=read();
For(i,n) {
a[i]=read();
}
int p=0;
For(i,n) Fork(j,i+1,n) if (a[i]<a[j]) p^=1;
puts(!p?"T":"Q");

return 0;
}

BZOJ 4976 宝石镶嵌

#include<bits/stdc++.h>
using namespace std;
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
For(j,m-1) cout<<a[i][j]<<' ';\
cout<<a[i][m]<<endl; \
}
#define
#define

typedef long long ll;
typedef unsigned long long ull;
ll mul(ll a,ll b){return (a*b)%F;}
ll add(ll a,ll b){return (a+b)%F;}
ll sub(ll a,ll b){return (a-b+llabs(a-b)/F*F+F)%F;}
void upd(ll &a,ll b){a=(a%F+b%F)%F;}
int read()
{
int x=0,f=1; char ch=getchar();
while(!isdigit(ch)) {if (ch=='-') f=-1; ch=getchar();}
while(isdigit(ch)) { x=x*10+ch-'0'; ch=getchar();}
return x*f;
}
int f[1<<17];
int a[123456];
int main()
{
// freopen("bzoj4976.in","r",stdin);
// freopen(".out","w",stdout);
int n=read(),k=read();
For(i,n) a[i]=read();
int mx=*max_element(a+1,a+1+n);
if (n>=k+17) {
int ans=0;
For(i,n) ans|=a[i];
cout<<ans<<endl;
} else {
MEMI(f) f[0]=0;
int S=1<<17;
For(i,n) {
Rep(st,S) gmin(f[st| a[i]] , f[st]+1);
}
int ans=0;
Rep(st,S) if (f[st]<=n-k) ans=st;
cout<<ans<<endl;
}
return 0;
}


标签:月赛,Lydsy,ch,return,八月份,int,ll,long,define
From: https://blog.51cto.com/u_15724837/5790201

相关文章

  • YACS 2022年9月月赛 甲组 T2 区间交集(三) 题解
    所以说,我又来贴标程了。这题有很多做法,线段树,优先队列$and$删除等等,这里分享一种码量极少的二分做法,主要思路:二分+动归#include<bits/stdc++.h>usingnamespacestd;......
  • YACS 2022年9月月赛 甲组 T1 游戏体验 题解
    目前还没有时间写题解,疯狂复习$CSP$复赛中,这题是个线段树(自己可以探究一下,是动态的)先贴个标程,需要的,请#include<bits/stdc++.h>usingnamespacestd;intn,m,a[10000......
  • Criss Cross OJ【R001】8月月赛I题解合集
    R0011.「T1」积木高塔Solution返回题目简要题意:给定一个矩阵,以及其每一格中完全相同立方体的高度(即个数),求:这座高塔最高点的高度。这座高塔从第\(1\)层到最高......
  • 牛客小白月赛56 A-F
    C题应该是最好的一道题 A阿宁的柠檬分析:酸度是[1,a]甜度是[0,b]总共有n个柠檬,问最小快乐值和最大快乐值最小就是n最大就是n*(a+b)voidsolve(){......
  • 牛客小白月赛56 A-F
    牛客小白月赛56A-Fhttps://ac.nowcoder.com/acm/contest/39100一场简单的比赛就足以验证我是多么的弱智。。。A-阿宁的柠檬求最大最小,签到。注意会爆\(int\)#inc......
  • 牛客小白月赛56
    A分别输出\(n,(a+b)n\)B输出\(m\)个\(1\)C对\((2^i,i)\)排序,对\(a_i\)排序,从小到大依次放入ans数组D求出小于等于\(10^7\)的所有素数,用set存起来,依次删......
  • 牛客小白月赛55 A-E
    牛客小白月赛55A-Ehttps://ac.nowcoder.com/acm/contest/38630F待补解析啥的睡醒再补,先放个代码A-至至子的等差中项#include<bits/stdc++.h>usingnamespaces......
  • 【新题】$\rm Lg$月赛 $P8476$ 「惊蛰」
    「你曾在名为弱小的深渊中,曾经看到过什么。」#include<bits/stdc++.h>usingnamespacestd;constintN=1e6+5;longlongcal[N]={0};namespaceOLD_CODE{......
  • 8.14 洛谷月赛
    感觉没有tg难\(\rmLink\)目录\(T1\)\(T2\)\(T3\)(主打\(div2\))\(T1\)这个\(T1\)是个神仙题,我甚至为它写了一个\(45pts\)的暴力分然后过去切了\(T2\)再回来看才......
  • 牛客小白月赛54 C School(思维)
    https://ac.nowcoder.com/acm/contest/38457/C爆时版本,想不明白D国的时间制度很奇怪,一天有h小时,一小时有m分。位于D国的校长给学生发放了校卡。这种校卡具......