首页 > 其他分享 >Codeforces Round 916 (Div. 3)(A~E2)

Codeforces Round 916 (Div. 3)(A~E2)

时间:2023-12-20 14:36:12浏览次数:31  
标签:maxx max rep Codeforces long Div 916 ll define

A
统计一下每个字母的出现次数然后输出即可

#include <bits/stdc++.h> 
#define rep(i,a,b) for(register int i = (a); i <= (b); ++i)
#define fep(i,a,b) for(register int i = (a); i >= (b); --i)
#define ls p<<1
#define rs p<<1|1
#define PII pair<int, int>
#define ll long long
#define ull unsigned long long
#define db double
#define endl '\n'
#define debug(a) cout<<#a<<"="<<a<<endl;
#define IOS ios::sync_with_stdio(false); cin.tie(0); cout.tie(0);
#define INF 0x3f3f3f3f 

using namespace std;
const int N = 1e5+10;
int t; 

void solve()
{
	int n; string str;
	cin >> n >> str;
	map<char,int>cnt;
	rep(i,0,str.size()-1)
	{
		cnt[str[i]]++;
	}
	int ans = 0;
	for(auto x:cnt)
	{
		int num=x.first-'A'+1;
		if(x.second>=num)	ans++;
	}
	cout << ans << endl;
}

int main()
{
	IOS	
//  	freopen("1.in", "r", stdin);
	cin >> t;
	while(t --)	
	solve();
	return 0;
}

B
前k个数是后n-k个数的顺序,后面的数逆序即可

#include <bits/stdc++.h> 
#define rep(i,a,b) for(register int i = (a); i <= (b); ++i)
#define fep(i,a,b) for(register int i = (a); i >= (b); --i)
#define ls p<<1
#define rs p<<1|1
#define PII pair<int, int>
#define ll long long
#define ull unsigned long long
#define db double
#define endl '\n'
#define debug(a) cout<<#a<<"="<<a<<endl;
#define IOS ios::sync_with_stdio(false); cin.tie(0); cout.tie(0);
#define INF 0x3f3f3f3f 

using namespace std;
const int N = 1e5+10;
int t,a[60]; 

void solve()
{
	int n, k, cnt=1; cin >> n >> k;
	rep(i,1,n)	a[i]=0;
	
	rep(i,n-k,n)	a[cnt++] = i;
	fep(i,n-k-1,1)	a[cnt++] = i;
	rep(i,1,n)	cout << a[i] << ' ';
	cout << endl;
}

int main()
{
	IOS	
//  	freopen("1.in", "r", stdin);
	cin >> t;
	while(t --)	
	solve();
	return 0;
}

C

#include <bits/stdc++.h> 
#define rep(i,a,b) for(register int i = (a); i <= (b); ++i)
#define fep(i,a,b) for(register int i = (a); i >= (b); --i)
#define ls p<<1
#define rs p<<1|1
#define PII pair<int, int>
#define ll long long
#define ull unsigned long long
#define db double
#define endl '\n'
#define debug(a) cout<<#a<<"="<<a<<endl;
#define IOS ios::sync_with_stdio(false); cin.tie(0); cout.tie(0);
#define INF 0x3f3f3f3f 

using namespace std;
const int N = 2e5+10;
int t; 
int a[N], b[N], s[N];
void solve()
{
	int n, k;	cin >> n >> k;
	rep(i,1,n)	s[i]=0;
	rep(i,1,n)	cin >> a[i], s[i] = s[i-1]+a[i];
	rep(i,1,n)	cin >> b[i];
	int maxx=-INF, ans=-INF;
	rep(i,1,min(k,n))
	{
		maxx=max(maxx, b[i]); 
		int cur=s[i]; cur+=max(0,k-i)*maxx;
		ans=max(cur,ans);		
	}
	cout << ans << endl;
}

int main()
{
	IOS	
//  	freopen("1.in", "r", stdin);
	cin >> t;
	while(t --)	
	solve();
	return 0;
}

D
考虑维护每一个数组前缀和后缀的最大值
然后考虑3种情况即那个数在中间
a、b、c均可以在中间,
a在中间有b a c和c a b两种情况
b在中间有a b c和c b a两种情况
c在中间有a c b和b a c两种情况
这里只说a在中间的情况
我们枚举a的位置\(i\in[2,n-1]\)
那么对于b a c,b在a左边所以就是b应选择的是\([1,i-1]\)中的最大值,也就是lb[i-1]
c在右边应选择的就是rc[i+1]
这种情况的最大值就是\(a[i]+lb[i-1]+rc[i+1]\)
然后对其他几种情况做同样的处理即可

#include <bits/stdc++.h> 
#define rep(i,a,b) for(register int i = (a); i <= (b); ++i)
#define fep(i,a,b) for(register int i = (a); i >= (b); --i)
#define ls p<<1
#define rs p<<1|1
#define PII pair<int, int>
#define ll long long
#define ull unsigned long long
#define db double
#define endl '\n'
#define debug(a) cout<<#a<<"="<<a<<endl;
#define IOS ios::sync_with_stdio(false); cin.tie(0); cout.tie(0);
#define INF 0x3f3f3f3f 

using namespace std;
const int N = 2e5+10;
int t, a[N], b[N], c[N]; 
int la[N], ra[N], lb[N], rb[N], lc[N], rc[N];

void solve()
{
	int n; cin >> n;
	rep(i,0,n+1)	la[i]=0,ra[i]=0,lb[i]=0,rb[i]=0,lc[i]=0,rc[i]=0;
	rep(i,1,n)	cin >> a[i];
	rep(i,1,n)	cin >> b[i];
	rep(i,1,n)	cin >> c[i];
	rep(i,1,n)	la[i] = max(la[i-1], a[i]);
	fep(i,n,1)	ra[i] = max(ra[i+1], a[i]);
	rep(i,1,n)	lb[i] = max(lb[i-1], b[i]);
	fep(i,n,1)	rb[i] = max(rb[i+1], b[i]);
	rep(i,1,n)	lc[i] = max(lc[i-1], c[i]);
	fep(i,n,1)	rc[i] = max(rc[i+1], c[i]);
	ll ans=0;
	rep(i,2,n-1)
	{
		ll maxx=0;
		maxx = max(maxx, (ll)a[i] + lb[i-1] + rc[i+1]);
		maxx = max(maxx, (ll)a[i] + lc[i-1] + rb[i+1]);
		maxx = max(maxx, (ll)b[i] + la[i-1] + rc[i+1]);
		maxx = max(maxx, (ll)b[i] + lc[i-1] + ra[i+1]);
		maxx = max(maxx, (ll)c[i] + la[i-1] + rb[i+1]);
		maxx = max(maxx, (ll)c[i] + lb[i-1] + ra[i+1]);
		ans = max(ans, maxx);
	}
	cout << ans << endl;
}

int main()
{
	IOS	
//  	freopen("1.in", "r", stdin);
	cin >> t;
	while(t --)	
	solve();
	return 0;
}

E1、E2
这道题目从数学的角度推公式比较好理解
考虑A、B选择的策略
考虑两列
a:x,y
b:u,v
a选择前面的得到的结果是x-1-(v-1)=x-v
a选择后面的得到的结果是y-1-(u-1)=y-u
哪个更优选择哪个
\((x-v)>(y-u) \rightarrow x+u > y+v也就是每个人会选择当前a[i]+b[i]\)值较大的这一列进行操作

#include <bits/stdc++.h> 
#define rep(i,a,b) for(register int i = (a); i <= (b); ++i)
#define fep(i,a,b) for(register int i = (a); i >= (b); --i)
#define ls p<<1
#define rs p<<1|1
#define PII pair<int, int>
#define ll long long
#define ull unsigned long long
#define db double
#define endl '\n'
#define debug(a) cout<<#a<<"="<<a<<endl;
#define IOS ios::sync_with_stdio(false); cin.tie(0); cout.tie(0);
#define INF 0x3f3f3f3f 

using namespace std;
const int N = 2e5+10;
int t; 
struct wy
{
	ll x, y, sum;
}a[N];
bool cmp(wy a, wy b)
{
	return a.sum > b.sum;
}
void solve()
{
	int n;	cin >> n;
	rep(i,1,n)	cin >> a[i].x;
	rep(i,1,n)	cin >> a[i].y, a[i].sum=a[i].x+a[i].y;
	sort(a+1,a+1+n, cmp);
	ll ans=0;
	rep(i,1,n)
	{
		if(i&1)	ans += a[i].x-1;
		else	ans -= a[i].y-1;
	}
	cout << ans << endl;
}

int main()
{
	IOS	
//  	freopen("1.in", "r", stdin);
	cin >> t;
	while(t --)	
	solve();
	return 0;
}

标签:maxx,max,rep,Codeforces,long,Div,916,ll,define
From: https://www.cnblogs.com/cxy8/p/17916417.html

相关文章

  • [Codeforces] CF1795C Tea Tasting
    CF1795CTeaTasting题意有\(n\)个人和\(n\)杯茶,第\(i\)个人每次会喝\(b_i\)毫升的茶。第\(i\)杯茶有\(a_i\)毫升。总共会喝\(n\)轮茶,第\(j\)轮第\(i\)个人会尝试喝第\(i+1-j\)杯茶。喝的量为\(\min(a_{i+1-j},b_i)\)毫升,并且使\(a_{i+1-j}\)减少\(\mi......
  • Educational Codeforces Round 160 (Rated for Div. 2) A~C
    A.RatingIncrease题意:将一个字符串分成两个整数a和b,要求没有前导0,且a<b思路:遍历字符串s,若当前位置不是0,则拆分字符串,比较大小//#include<bits/stdc++.h>#include<iostream>#include<string>#include<cstring>#include<vector>#include<algorithm>#inclu......
  • Educational Codeforces Round 160 (Rated for Div. 2)
    基本情况A题秒了。B题卡了实在太久,BC题最后虽然都过了,但是耗时太久。感觉C对我来说更好写。B.SwapandDelete经典+3。总是一条路偏要走到黑了才会想着换思路,早该换了。一开始想了一大堆乱七八糟的思路,但都错了。后面往简单了想,这题毕竟最后必须要左对齐的,直接从左往右比......
  • Square-free division (easy version) 题解
    题意:给定一个长度为\(n\)的序列,求最少能将这个序列分成多少段使得任意一段中不存在两个数的积为完全平方数。一个小Trick:如果两个数乘起来为平方数,可以先将每个数的平方因子除掉,然后这两个数必然相等。于是这道题被转化为了一个区间不能有相等的值,这就很典了。设\(pos_{a_{i......
  • 【题解】CodeForces-1913
    CodeForces-1913ARatingIncrease依题意模拟。提交记录:Submission-CodeForcesCodeForces-1913BSwapandDelete交换免费就是能任意重排,从头开始尽量填相反的,剩下只能删去了。提交记录:Submission-CodeForcesCodeForces-1913CGamewithMultiset从大到小能减则减一定......
  • 【题解】CodeForces-1905
    CodeForces-1905AConstructiveProblems发现沿着对角线放就行了,答案是\(\max(n+m)\)。提交记录:Submission-CodeForcesCodeForces-1905BBegginer'sZelda最优操作每次删两个叶子(除了最后一次只剩两个节点),所以答案是叶子个数除以二上取整。提交记录:Submission-CodeForc......
  • BIgdataAIML-IBM-A neural networks deep dive - An introduction to neural networks
    https://developer.ibm.com/articles/cc-cognitive-neural-networks-deep-dive/ByM.TimJones,PublishedJuly23,2017Neuralnetworkshavebeenaroundformorethan70years,buttheintroductionofdeeplearninghasraisedthebarinimagerecognitionand......
  • 使用遍历后数据加入新的div块中
    我们经常使用的数据他会成一个整体放入块中,但我们有时需要将他们分开使用,让他们展示在不同的div块中。所以就有了今天这篇博文。我们经常使用的遍历是这样的vararr=[5,3,8,2,4,9,6]for(vari=0;i<=a.length-1;i++)但我们遍历以后怎么去给他放入新的div块中呢所以我们要创......
  • Codeforces Round 834 (Div. 3)
    CodeforcesRound834(Div.3)A.Yes-Yes?题意:就是Y后面跟e,e后面跟s,s后面跟Y#include<iostream>usingnamespacestd;voidsolve(){stringx;cin>>x;intl=x.size();if(l==1){if(x[0]!='Y'&&x[0]!='e&#......
  • Codeforces Round 839 (Div. 3)
    CodeforcesRound839(Div.3)A.A+B?跳过太水了、、、、、#include<bits/stdc++.h>usingnamespacestd;intmain(){intt;cin>>t;while(t--){inta,b;scanf("%d+%d",&a,&b);cout<<a+......