1526== 水水的..并查集
1527== 地大比赛我们见过
1528 == 某种算法模板题
1529 == 水水的...
1530 == 水水的...因为最多只有26个字母,所以可以暴力
1531 == 水水的...多重背包
1532 == 水水的,每个点必须拿,所以可以直接dfs..
1526
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
#define N 100010
int p[N];
int n,m;
int a,b;
inline int find(int x)
{
if(p[x]!=x) return p[x]=find(p[x]);
return x;
}
int main()
{
while(~scanf("%d",&n))
{
if(n==0) break;
scanf("%d",&m);
for(int i=1;i<=n;i++) p[i]=i;
for(int i=1;i<=m;i++)
{
scanf("%d%d",&a,&b);
int x=find(a);
int y=find(b);
if(p[x]!=y) p[x]=y;
}
int ans=0;
for(int i=1;i<=n;i++)
{
if(find(i)==i) ans++;
}
printf("%d\n",ans);
}
return 0;
}
1527
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
#define N 100010
int n,a[N*2],dp[N*2],sum;
int tag;
int main()
{
while(~scanf("%d",&n))
{
int flag=0;
for(int i=0;i<n;i++)
{
scanf("%d",&a[i]);
if(a[i]>0) flag=1;
a[i+n]=a[i];
}
if(!flag) printf("0\n");
else
{
sum=a[0];
dp[0]=a[0];
tag=1;
for(int i=1;i<2*n;i++)
{
if(dp[i-1]<0)
{
dp[i]=a[i];
tag=1;
}
else
{
dp[i]=dp[i-1]+a[i];
tag++;
}
if(tag>n)
{
int b=0;
int s=0,p=i,r=n;
for(int j=i;r>0;j--,r--)
{
b+=a[j];
if(b>s)
{
s=b;
p=j;
}
}
dp[i]=s;
tag=i-p+1;
}
}
int ans=0;
for(int i=0;i<2*n;i++) ans=max(ans,dp[i]);
printf("%d\n",ans);
}
}
return 0;
}
1528
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
#define N 200010
char s[N],s1[N*2];
int l,p[N*2];
void change()
{
s1[0]='$';
s1[1]='#';
for(int i=0;i<l;i++)
{
s1[i*2+2]=s[i];
s1[i*2+3]='#';
}
l=l*2+2;
s[l]='#';
}
void getp()
{
int id,mx=0,i;
p[0]=0;
for(i=l;s1[i]!=0;i++) s1[i]=0;
for(i=1;i<l;i++)
{
if(i<mx) p[i]=min(p[id-(i-id)],mx-i);
else p[i]=1;
while(s1[i-p[i]]==s1[i+p[i]]) p[i]++;
if(p[i]>mx)
{
id=i;
mx=p[i]+i;
}
}
}
int main()
{
while(~scanf("%s",s))
{
l=strlen(s);
change();
getp();
int ans=0;
for(int i=1;i<l;i++)
ans=max(ans,p[i]-1);
printf("%d\n",ans);
}
}
1529;
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
int map[10][10];
int dp[10][10];
int main()
{
while(~scanf("%d",&map[1][1]))
{
for(int i=1;i<=8;i++)
for(int j=1;j<=8;j++)
{
if(i==1&&j==1) continue;
scanf("%d",&map[i][j]);
}
memset(dp,0,sizeof(dp));
for(int i=1;i<=8;i++)
for(int j=1;j<=8;j++)
{
dp[i][j]=max(dp[i][j],dp[i-1][j]+map[i][j]);
dp[i][j]=max(dp[i][j],dp[i][j-1]+map[i][j]);
}
printf("%d\n",dp[8][8]);
}
return 0;
}
1530
#include<stdio.h>
#include<string.h>
char s[10010];
int vis[26];
int main()
{
while(~scanf("%s",s))
{
int ans=0;
int l=strlen(s);
for(int i=0;i<l;i++)
{
memset(vis,0,sizeof(vis));
int temp=0;
for(int j=i;j<l;j++)
{
int a=s[j]-'a';
if(!vis[a])
{
vis[a]=1;
temp++;
}
else break;
}
ans=(ans<temp?temp:ans);
}
printf("%d\n",ans);
}
return 0;
}
1531
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
int f[100*100+10];
void zero(int c,int w)
{
for(int i=10000;i>=c;i--)
f[i]=max(f[i-c]+w,f[i]);
}
void com(int c,int w)
{
for(int i=c;i<=10000;i++)
f[i]=max(f[i-c]+w,f[i]);
}
void mut(int c,int w,int num)
{
if(c*num>=10000) com(c,w);
else
{
int k=1;
while(k<=num)
{
zero(k*c,k*w);
num-=k;
k*=2;
}
zero(num*c,num*w);
}
}
int w[110];
int main()
{
int n;
int num[110];
while(scanf("%d",&n)!=EOF)
{
memset(num,0,sizeof(num));
for(int i=1;i<=n;i++)
scanf("%d",&w[i]),num[w[i]]++;
memset(f,0,sizeof(f));
for(int i=1;i<=100;i++) mut(i,i,num[i]);
int ans=0;
for(int i=1;i<=10000;i++)
if(f[i]!=i)
{
ans=i;break;
}
printf("%d\n",ans);
}
return 0;
}
1532
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
int map[10][10];
int dp[10][10];
int li;
int ans;
inline void dfs(int x,int y,int sum)
{
if(sum>li) return;
if(x>8) return;
if(y>8) return;
if(x==8&&y==8&&sum+map[8][8]<=li)
{
sum+=map[x][y];
ans=max(ans,sum);
return;
}
else
{
dfs(x+1,y,sum+map[x][y]);
dfs(x,y+1,sum+map[x][y]);
}
}
int main()
{
while(~scanf("%d",&li))
{
for(int i=1;i<=8;i++)
for(int j=1;j<=8;j++)
{
scanf("%d",&map[i][j]);
}
memset(dp,0,sizeof(dp));
ans=-1;
dfs(1,1,0);
printf("%d\n",ans);
}
return 0;
}