「蓝桥·算法双周赛」第一场公开赛

三带一【算法赛】 - 蓝桥云课 (lanqiao.cn)

给定四个字符,判断是否其中有三个相同,另一个与他们不同

#include 
void solve()
{
  std::string s;
  std::cin>>s;
  char a=s[0],b=s[1],c=s[2],d=s[3];
  if(a==b&&a==c&&a!=d) std::cout<<"Yes"<<'\n';
  else if(a==b&&a==d&&a!=c) std::cout<<"Yes"<<'\n';
  else if(a==d&&a==c&&a!=b) std::cout<<"Yes"<<'\n';
  else if(d==b&&d==c&&a!=d) std::cout<<"Yes"<<'\n';
  else std::cout<<"No"<<'\n';
}
signed main()
{
  int t;
  std::cin>>t;
  while(t--)
  {
    solve();
  }
  return 0;
}

 数树数【算法赛】 - 蓝桥云课 (lanqiao.cn)

 二叉树性质问题,不了解二叉树也完全可以做。

要注意的是每次都从第一行的第一个点开始走,给一个字符串按照它走,输出最后的结果就行。

往左走坐标就变成了2*pos-1,往右就变成了2*pos

画个树理解一下就好了。

「蓝桥·算法双周赛」第一场公开赛_第1张图片

#include 

signed main()
{
	int n,q;
	std::cin>>n>>q;
	int pos=1;
	while(q--)
	{
		pos=1;
		std::string s;
		std::cin>>s;
		int i=0;
		while(s[i])
		{
			if(s[i]=='L') 
			{
				pos=2*pos-1;
			}else if(s[i]=='R'){
				pos*=2; 
			}
			i++;
		}
		std::cout<

 分组【算法赛】 - 蓝桥云课 (lanqiao.cn)

这题是二分。

二分极差,然后判断如果以该极差来分组,所分的组数能否小于k(如果小于k,那么k肯定能满足。因为一个数可以单独成一组,即极差为0),如果能就减小极差继续试探,否则增大极差。

#include
const int N=1e5+10;
int a[N];
int n,k;

bool check(int x)
{
  int last=1,cnt=1;
  for(int i=1;i<=n;i++)
  {
    if(a[i]-a[last]>x)//如果当前这个不行就分组
    {
      last=i;
      cnt++;
    }
  }
  return cnt<=k;
}
signed main()
{
  std::cin>>n>>k;

  for(int i=1;i<=n;i++) std::cin>>a[i];
  std::sort(a+1,a+1+n);

  int l=0,r=2e9,res=0;//枚举极差
  while(l<=r)
  {
    int mid=l+r>>1;
    if(check(mid)) 
    {
      res=mid;
      r=mid-1;
    }else l=mid+1;
  }
  std::cout<

健身【算法赛】 - 蓝桥云课 (lanqiao.cn)

十年OI一场空,不开longlong见祖宗。

这道题是一个完全背包问题,需要注意的是si范围是1e9,不开longlong会死。

首先dp预处理出 对应连续天数 能收获的最大分数。

然后对连续天数进行计算,每算出一个连续天数就加上对应的分数。

#include 
const int N=2e5+10;
#define int long long
int n,m,q;
int cantuse[N],k[N],s[N];
struct st{
	int k,s;
}a[N];
int res,cnt;
int f[N];
#define int long long
void solve()//有i天怎么用最大化 
{
	for(int i=1;i<=m;i++)//对物品遍历 
	{
		for(int j=a[i].k;j<=n;j++)//对容积遍历 
		{
			f[j]=std::max(f[j],f[j-a[i].k]+a[i].s);
		}
	}
}
signed main()
{
	std::cin>>n>>m>>q;	
	for(int i=1;i<=q;i++)
	{
		int d;
		std::cin>>d;
		cantuse[d]=1;
	}
	for(int i=1;i<=m;i++)
	{
		std::cin>>a[i].k>>a[i].s;
		a[i].k=pow(2,a[i].k);
	}
	solve();
	f[0]=0;
	for(int i=1;i<=n;i++)
	{
		if(!cantuse[i]) cnt++;
		else{
			res+=f[cnt];
			cnt=0;
		}
	}
	if(cnt) res+=f[cnt];
	std::cout<

 契合匹配【算法赛】 - 蓝桥云课 (lanqiao.cn)

把一个串大小写转换,然后破换成链,这题要KMP,博主不会 

你可能感兴趣的:(算法)