铁子和顺溜在学习了博弈论的sg函数之后,解决了很多很多博弈题,现在他们遇到了一道难题。
给出一个长度为 n 的数列,数列里的每个元素都是个位数,这个数列的每一个连续子数列都能生成
一个十进制数,对于子数列a[l~r],这个十进制数的个位为a[r],十位为a[r - 1],...,最高位
为a[l]。
现在铁子需要知道最小的不能被该数列的子数列生成的十进制非负整数是多少?
给出一个长度为 n 的数列,数列里的每个元素都是个位数,这个数列的每一个连续子数列都能生成
一个十进制数,对于子数列a[l~r],这个十进制数的个位为a[r],十位为a[r - 1],...,最高位
为a[l]。
现在铁子需要知道最小的不能被该数列的子数列生成的十进制非负整数是多少?
输入描述:
第一行一个数字n。(1 ≤ n ≤ 1000)
第二行n个数字di。(0 ≤ di ≤ 9)
输出描述:
输出一个数字表示答案。
思路:这题把我吓懵了,结果是个取巧的典型。因为求最小,数列生成的四位数为O(n)个,所以不可能超过10000,然后暴力..........
代码如下:
#include<iostream>
#include <cstring>
using namespace std;
const int M = 1000;
int a[M];
int sg[M];
int main()
{
int n;
int ans;
while (scanf("%d", &n) != EOF)
{
memset(sg, 0, sizeof(sg));
for (int i = 0; i < n; i++)
scanf("%d", &a[i]);
for (int i = 0; i < n; i++)
{
ans = 0;
for (int j = i; j < n&&j < i + 3; j++)
{
ans = ans * 10 + a[j];
sg[ans]++;
}
}
for (int i = 0; i < M; i++)
{
if (!sg[i])
{
printf("%d\n", i);
break;
}
}
}
return 0;
}
铁子的班级在毕业晚会有一个合唱节目,到了毕业晚会的时候,他们必须排成一排一起合唱"认错","当然是选择原谅他"等一系列原谅歌曲,但是当队形布置好的时候,领导们觉得队形里最长的连续的女生的长度太小了,但是由于马上要开始演唱,所以最多只能两个人交换位置,问新队形中最长的连续的女生的长度是多少?
输入描述:
第一行一个数字n表示铁子班级的总人数。1≤n≤105
第二行一个字符串s表示最初的队形布置,si=0表示第i个人是女生,si=1表示第i个人是男生。
输出描述:
输出一行表示答案
思路:........记录每2个男生之间女孩的数量,然后进行操作取最大。
代码如下:
#include<bits/stdc++.h>
using namespace std;
int main()
{
int n,i,f[100005];
char a[100005];
memset(f,0,sizeof(f));
scanf("%d %s",&n,a);
int ans=0,sum=0,k=0;
for(i=0;i<n;i++)
if(a[i]=='0')
{
sum++;
f[k]++;//第k个男孩位置往后到下一个男孩间的女孩数量
}
else
k++;//k为男孩的数量
for(i=1;i<=k;i++)
ans=max(ans,f[i-1]+f[i]);//交换i处时合并前后串 f[i-1]为上一个男孩与下一个男孩中间的女孩数,f[i]同理
if(sum==n||ans==sum)//避免交换时特殊情况产生的减少
printf("%d\n",sum);
else
printf("%d\n",ans+1);
return 0;
}
反思:这学期练习模板题较多,感觉产生了一定的依赖性,脑子也不怎么动,结果就是这次小白赛呵呵哒了,最近也是运气极为不佳,上次距离牛客衣服差1名,这次差2名.........自己越来越水,,,好颓废好颓废,快期末考试了,还要忙着复习。每天2个小时的代码时间怕是要保不住了......都说acm是比智商,我需要多锻炼锻炼我的脑子,避免被各种花式吊打。