首页 > 其他分享 >2024.3.24题

2024.3.24题

时间:2024-03-24 18:22:21浏览次数:31  
标签:24 2024.3 cout int cin long vector tie

广州大学第十八届ACM大学生程序设计竞赛(同步赛)

https://ac.nowcoder.com/acm/contest/77448
一. 能赢吗?会赢的!
取整函数:https://blog.csdn.net/aouixh/article/details/53483556

  1. ceil(): double向上取整。
  2. floor():向下取整。
  3. round():(环绕,取其大约)。四舍五入函数。
#include<bits/stdc++.h>
using namespace std;
#define int long long

signed main()
{
	ios::sync_with_stdio(false);cin.tie(nullptr);cout.tie(nullptr);
	int n;
	cin>>n;
	vector<int>a(n);//保证a[i]不改变。
	for(int i=0;i<n;i++){
		cin>>a[i];
	}
	int sum=0;//护盾值的累加。
	vector<int>b(n);//每个boss刷新后的护盾值加血量。
	vector<int>c(n);//击败每个boss需要的初始战力。
	c[0]=a[0];
	for(int i=0;i<n;i++)
	{
		b[i]=a[i];
		if(i>0)
		{
			b[i]+=ceil(a[i-1]/2.0);
			sum+=floor(a[i-1]/2.0);
			c[i]=b[i]-sum;//新血量-当前增加能力值=初始能力值。
		}
	}
	sort(c.begin(),c.end());
	cout<<c[n-1]+1<<endl;//取最大加一
	return 0;
}

二. 计算几何
因为保证数据不存在相同坐标的点。所以可以根据点的特征来排序:

  1. 如果两个点的纵坐标是当前剩余点最小的。那么两个点和其他的点不会相交。
  2. 如果两个点纵坐标相同,那么横坐标按照从0->∞排序,使每个点都彼此错开。
#include<bits/stdc++.h>
using namespace std;
#define int long long
bool cmp(pair<int,pair<int,int>>a,pair<int,pair<int,int>>b)
{
	if(a.second.second!=b.second.second)
		return a.second.second<b.second.second;
	else
	{
		return a.second.first>b.second.first;
	}
	
}
signed main()
{
	ios::sync_with_stdio(false);
	cin.tie(nullptr);
	int n;
	cin>>n;
	vector<pair<int,pair<int,int>>>a(n);
	for(int i=0;i<n;i++)
	{
		cin>>a[i].second.first>>a[i].second.second;
		a[i].first=i+1;
	}
	sort(a.begin(),a.end(),cmp);
	if(n%2==0)
	{
		cout<<n/2<<endl;
		for(int i=0;i<n;i+=2)
		{
			cout<<a[i].first<<" "<<a[i+1].first<<endl;
		}
	}else
	{
		cout<<n/2<<endl;
		for(int i=0;i<n;i+=2)
		{
			if(i+1<n)
				cout<<a[i].first<<" "<<a[i+1].first<<endl;
		}
	}
	return 0;
}

三. 矩阵最大路径与

^_^dp动态规划的blog(待完成):https://www.cnblogs.com/miao-jc/p/18092141

//以后会懂的。
#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N=1e5+10;


signed main()
{
	ios::sync_with_stdio(false);cin.tie(nullptr);cout.tie(nullptr);
	int n,m;
	cin>>n>>m;
	vector<vector<int>>a(n,vector<int>(m));
	for(int i=0;i<n;i++)
	{
		for(int j=0;j<m;j++)
		{
			cin>>a[i][j];
		}
	}
	int k=a[0][0]&a[n-1][m-1];
	vector<vector<int>>st(n,vector<int>(m,0));
	
	vector<int>dx={1,0,-1,0};
	vector<int>dy={0,-1,0,1};
	
	auto check=[&](int x)
	{
		for(int i=0;i<n;i++)
		{
			for(int j=0;j<m;j++)
			{
				st[i][j]=0;
			}
		}
		queue<array<int,2>>q;
		
		q.push({0,0});
		while(q.size())
		{
			auto[xx,yy]=q.front();
			q.pop();
			if(xx==n-1 and yy==m-1)
				return 1;
			if(st[xx][yy])
				continue;
			st[xx][yy]=1;
			for(int i=0;i<4;i++)
			{
				int nx=xx+dx[i],ny=yy+dy[i];
				if(nx<0 or nx>=n or ny<0 or ny>=m or st[nx][ny] or (a[nx][ny]&x)!=x)
					continue;
				q.push({nx,ny});
			}
		}
		return 0;
	};
	int res=0;
	for(int i=30;i>=0;i--)
	{
		if(!(k>>i&1))
			continue;
		int t=res+(1<<i);
		bool flag =check(t);
		if(flag)
			res+=(1<<i);
	}
	cout<<res;
	return 0;

}

牛客周赛 Round 36
https://ac.nowcoder.com/acm/contest/76609
小红走矩阵

#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N=1e5+10;
int minstep(vector<vector<char>>&mm,int n,int m)
{
	vector<vector<int>>step(n,vector<int>(m,-1));
	vector<int>dx={0,0,1,-1};
	vector<int>dy={1,-1,0,0};
	queue<pair<int,int>>q;
	step[0][0]=0;
	q.push({0,0});
	while(!q.empty())
	{
		pair<int,int>cur=q.front();
		q.pop();
		for(int i=0;i<4;i++)
		{
			int x=cur.first+dx[i];
			int y=cur.second+dy[i];
			if(x>=0&&x<n&&y<m&&mm[x][y]!=mm[cur.first][cur.second]&&step[x][y]==-1)
			{
				step[x][y]=step[cur.first][cur.second]+1;
				//走到下一个格子的步数等于上一个格子数加一。
				q.push({x,y});
				//把可以走到的格子装到队列里
			}
		}
	}
	return step[n-1][m-1];
}

signed main()
{
	ios::sync_with_stdio(false);cin.tie(nullptr);cout.tie(nullptr);
	int n,m;
	cin>>n>>m;
	vector<vector<char>>mm(n,vector<char>(m));
	for(int i=0;i<n;i++)
	{
		for(int j=0;j<m;j++)
		{
			cin>>mm[i][j];
		}
	}
	int r=minstep(mm,n,m);
	if(r==-1)
	{
		cout<<"-1"<<endl;
		//初始化为-1,如果是-1的话就没有走到。
	}else 
	{
		cout<<r<<endl;
	}
	return 0;
}

天梯赛训练

https://vjudge.net/contest/617184#problem/H
P1098 [NOIP2007 提高组] 字符串的展开
https://www.luogu.com.cn/problem/P1098
1、s.erase(x,y) :表示将字符串s从x位置起删除y个字符

2、s.insert(x,y) :表示将字符串y(或字符y)插入到s的x位置处

3、s.push_back(x) :表示在s的末尾插入字符x

4、reverse(s.begin(),s.end()) :将字符串s翻转

#include<bits/stdc++.h>
using namespace std;
#define int long long
signed main()
{
	int a,b,c;
	cin>>a>>b>>c;
	string s,t;
	cin>>s;
	for(int i=0;i<s.size();i++)
	{
		if(s[i]!='-')cout<<s[i];
		else
		{
			auto l=s[i-1],r=s[i+1];
			if('0'<=l and l<='9' and '0'<=r and r<='9')
			{
				if(l>=r)
				{
					cout<<'-';
					continue;
				}
				t="";
				for(l++;l<r;l++)
				{
					for(int j=0;j<b;j++)
					{
						if(a<=2)
							t+=l;
						else 
							t+='*';
					}
				}if(c==2)
				{
					reverse(t.begin(),t.end());
				}
				cout<<t;
			}else if('a'<=l and l<='z' and 'a'<=r and r<='z')
			{
				if(l>=r)
				{
					cout<<'-';
					continue;
				}
				t="";
				for(l++;l<r;l++)
				{
					for(int j=0;j<b;j++)
					{
						if(a==1)
							t+=l;
						else if(a==2)
						{
							t+=l+'A'-'a';
						}else
						{
							t+='*';
						}
					}
				}
				if(c==2)
					reverse(t.begin(),t.end());
				cout<<t;
			}else{
				cout<<"-";
			}
		}
	}
	return 0;
}

P2058 [NOIP2016 普及组] 海港

#include<bits/stdc++.h>
using namespace std;
#define int long long
int n,t,m,x;
int nation[1000005];
int sum;
struct node
{
	int s,t;//只要开个结构体存人头数
};
queue<node>ship;
node h;
signed main()
{
	ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
	
	cin>>n;
	for(int i=1;i<=n;i++)
	{
		cin>>t>>m;
		while(!ship.empty())//只要还有人就对队列进行检查
		{
			h=ship.front();//循环取队头(由于时间是单调递增的)
			if(h.t+86400<=t)//如果在时间外(不符合条件),则对答案和队列进行更新(删减)
			{
				nation[h.s]--;//这个国籍人数总数减1(因为这不是24小时内的人)
				if(nation[h.s]==0)
				{
					sum--;//如果这个国籍没有人了,则答案数减1(之前记过)
				}
				ship.pop();
				continue;//因为是单调递增的,所以有可能还会有,继续去找
			}
			break;//如果现在这个在24小时内,后面的肯定也符合条件,直接退出
		}
		for(int j=1;j<=m;j++)
		{
			cin>>x;
			h.s=x,h.t=t;
			ship.push(h);
			nation[x]++;//这个国籍的人加1
			if(nation[x]==1)
				sum++;//如果这个国籍是1,相对第一次出现,那么就算上他
		}
		cout<<sum<<endl;
	}
	return 0;
}

四川农业大学新生选拔赛

【模板】01背包
https://blog.csdn.net/kingxzq/article/details/136465242
你有一个背包,最多能容纳的体积是V。
现在有n个物品,第i个物品的体积为vi,价值为wi。

(1)求这个背包至多能装多大价值的物品?
(2)若背包恰好装满,求至多能装多大价值的物品?

#include<bits/stdc++.h>
using namespace std;
#define int long long
#define INF -999999
const int N=1e5+10;
int dp[1005],v[1005],w[1005];


signed main()
{
	ios::sync_with_stdio(false);cin.tie(nullptr);cout.tie(nullptr);
	int n,V;
	cin>>n>>V;//物品个数,背包体积。

	for(int i=1;i<=n;i++)
	{
		cin>>v[i]>>w[i];//体积,价值
	}
	for(int i=1;i<=n;i++)
	{
		for(int j=V;j>=v[i];j--)
		{
			dp[j]=max(dp[j],dp[j-v[i]]+w[i]);
		}
	}
	cout<<dp[V]<<endl;
	memset(dp,-0x3f,sizeof(dp));
	dp[0]=0;
	for(int i=1;i<=n;i++)
	{
		for(int j=V;j>=v[i];j--)
		{
			dp[j]=max(dp[j],dp[j-v[i]]+w[i]);
		}
	}
	if(dp[V]<0)
		dp[V]=0;
	cout<<dp[V]<<endl;
	return 0;
}

取石子游戏 1

关键就是何时石子数目达到 x(k+1),其中x为任意整数,从这一刻起,无论这一刻以后首个拿石子的人(注意:“这一刻以后”为定语,这个人不一定是整个游戏首个拿石子的人)拿几个石子,另一位聪明的玩家一定会保证二者所拿石子数之和为k+1来保证他自己赢。
故对于整个游戏的先手来说,他一定要在游戏开始石子数为 x(k+1)+s,s<k 时拿走s个石子来取胜,而如果开始时石子数便为x(k+1),只要对手足够聪明他就必输。

#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N=1e5+10;

signed main()
{
	ios::sync_with_stdio(false);cin.tie(nullptr);cout.tie(nullptr);
	int n,k;
	cin>>n>>k;
	if(n%(k+1)!=0)
	{
		cout<<"1"<<endl;
	}else
	{
		cout<<"2"<<endl;
	}
	return 0;
}

P4391 [BOI2009] Radio Transmission 无线传输
https://www.luogu.com.cn/problem/P4391

KMP算法????????????

标签:24,2024.3,cout,int,cin,long,vector,tie
From: https://www.cnblogs.com/miao-jc/p/18092073

相关文章

  • 2024-03-24
    \({\color{Orange}\star}\)2024-03-24\({\color{Orange}\star}\)完全平方数题意就是求出第\(k\)个不是完全平方数的倍数的数随着数\(n\)的增加\([1,n]\)的满足条件的数的个数是单调不降的可以二分\(n\)的值,然后算出\([1,n]\)中满足条件的数的个数,根据它与\(k\)......
  • 3.24
    所花时间:2小时代码量:63博客篇:1每日学习打卡功能实现packagecom.example.studyapplication;importandroid.content.SharedPreferences;importandroid.os.Bundle;importandroid.os.Looper;importandroid.util.Log;importandroid.view.View;importandroid.widget.......
  • 0318-0324题解
    成信大天梯赛L1-6二进制因为二进制是逢二进一,所以我们只要用cnt记录一下每一位上的数并给它加起来,然后cnt%2便是其和这一位上的数,注意要从右往左开始点击查看代码#include<bits/stdc++.h>usingnamespacestd;typedefpair<int,int>pii;voidsolve(){stringa,b......
  • 20240318-2-推荐算法Graph_Embedding
    GraphEmbedding在许多推荐场景下,可以用网络结构数据来刻画对象(用户、商品等)之间的关系。例如:可以将用户和商品作为网络中的结点,用户和商品之间的边代表购买关系。GraphEmbedding是一种将网络中对象之间的关系转换为每个对象的(向量)特征的一种技术。其主要想法是输入网......
  • 20240318-1-推荐算法gbdt_lr
    gbdtlrgbdt+lr是facebook提出在线广告模型,我们知道LR之前在广告和推荐系统由于其快速的计算而被广泛使用,使用由于lr是线性模型,其模型表现能力不强,需要做大量的特征工程。facebook提出提出使用决策树进行特征embedding。为了提升线性分类器的准确度,有两种方法进行特征......
  • 3/24——周报-最近训练的情况
    PTA自主训练1:自主训练2:洛谷VJ牛客总结做题数量不够,思路匮乏,正在学习算法,对一些算法深层的理解不到位。望继续努力,拿出热情。......
  • 24.Spring Security OAuth2
    1.基本概念1.1.什么是认证进入移动互联网时代,大家每天都在刷手机,常用的软件有微信、支付宝、头条等,下边拿微信来举例子说明认证相关的基本概念,在初次使用微信前需要注册成为微信用户,然后输入账号和密码即可登录微信,输入账号和密码登录微信的过程就是认证。系统为什么要认证?认......
  • 3月24日 装错信封
    3.5ProblemE:深入浅出学算法031-装错信封任务内容清明时节雨纷纷,写封信件祭先人。无奈信件实在多,错装信封把信混。现写了n封信和n个信封,把所有的信都装错信封的情况共有多少种?Input多组测试数据,每组输入1个整数n(10>=n>=2).Output对于每组测试数据输出一行,值为所......
  • 牛客--2024中国传媒大学程序设计大赛(同步赛)
    A-小苯的区间和疑惑题意:做法:前缀最大值+后缀最大值 or 线段树维护最大子段和intarr[200005],pre[200005],last[200005];voidsolve(){//小笨的区间和疑惑--前缀最大值+后缀最大值or线段树维护最大自段和intn;cin>>n;for(inti=1;i<=n;i++)cin......
  • 20240324每日一题题解
    20240324每日一题题解Problem给两个按照非递减顺序排列的整数数组num1和num2,另外有两个整数m和n,分别表示num1和num2中的元素数目。请合并num2到num1中,使得合并后的数组还是按照非递减顺序排列。注意,需要将合并之后的数组还是存储在数组num1中。示例1:输入:nums1=[1,2,3,0,......