首页 > 其他分享 >2024.4.7

2024.4.7

时间:2024-04-07 17:25:04浏览次数:26  
标签:10 2024.4 输出 int 输入 数据 dp

2024.4.7 【南天寂静亮星少,北落师门赛明灯。】

Sunday 二月三十


<theme = oi-"search">

A. 填充单词

题目描述
小C认识很多单词,但是他并不喜欢其中的一些单词。具体地说,如果一个单词包含连续的3个元音字母,或连续的3个辅音字母,或者1个“L”字母都不包含的话,这个单词是不被小C喜欢的。其中元音字母仅为A、E、I、O、U这5个字母,剩下的字母全部为辅音字母。

现在给你一个部分残缺的单词,问一共有多少种方法用26个字母来填满这个单词,使得小C是喜欢这个单词的?

格式
输入格式
输入仅一行包括 1 个长度不超过100 的全部由字符串,表示残缺的单词,其中残缺的部分用'_' 表示。

输出格式
输出仅一行,包括1 个正整数,表示不同的方案数。这个数字可能会很大,请用long long存储。

Samples
输入数据 1

L_V

输出数据 1

5

输入数据 2

V__K

输出数据 2

10

输入数据 3

JA_BU_K_A

输出数据 3

485

数据范围与提示
10组测试数据下划线的个数为3,5,6,7,9,10,10,10,10,10
搜索做法

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
string s;
ll ans;int cnt,tl;
char w[30]={'A','E','I','O','U','y','f'};
bool yuan(char d){
	for(int i=0;i<6;++i){
		if(d==w[i])return 1;
	}
	return 0;
}
ll ksm(ll a,ll b){
	ll num=1;
	while(b>0){
		if(b&1)num=num*a;
		a=a*a;
		b>>=1;
	}
	return num;
}
void dfs(int p,int y,int ty,int t_y){
	if(p>int(s.size())-1){
		if(tl==1){
			ans+=ksm(5,t_y)*ksm(21,cnt-t_y);
		}
		else ans+=ksm(5,t_y)*(ksm(21,cnt-t_y)-ksm(20,cnt-t_y));
		return;
	}
	if(yuan(s[p])){
		ty=max(1,ty); 
		if(y==p-1&&y!=0){
			++ty;
			if(ty==3)return;
		}
		y=p;
	}
	else{
		ty=0;
	}
	if(p-y>=3)return;
	if(s[p+1]=='_'){
		s[p+1]='y';
		dfs(p+1,y,ty,t_y+1);
		s[p+1]='f';
		dfs(p+1,y,ty,t_y);
		s[p+1]='_';
	}
	else dfs(p+1,y,ty,t_y);
	return;
}
int main(){
	ios::sync_with_stdio(false);
	cin.tie(nullptr);
	//freopen("A.in","r",stdin);
	//freopen(".out","w",stdout);
	cin>>s;
	s='0'+s;
	for(int i=1;i<=int(s.size())-1;++i){
		if(s[i]=='_')++cnt;
		if(s[i]=='L')tl=1;
	}
	dfs(0,0,0,0);
	cout<<ans<<endl;
	return 0;
}

DP做法

#include<bits/stdc++.h>
using namespace std;
#define ll long long
const int maxn = 110;
ll dp[maxn][5][2];
char s[maxn];
int main(){
	cin>>s;
	int n = strlen(s);
	for(int i = n;i > 0;i--){
		s[i] = s[i-1];
	} 
	if(s[1] == '_'){
		dp[1][1][0] = 0,dp[1][2][0] = 0,dp[1][3][0] = 5,dp[1][4][0] = 20;
		dp[1][1][1] = 0,dp[1][2][1] = 0,dp[1][3][1] = 0,dp[1][4][1] = 1;
	}
	else if(s[1] == 'A'||s[1] == 'E'||s[1] == 'I'||s[1] == 'O'||s[1] == 'U'){
		dp[1][1][0] = 0,dp[1][2][0] = 0,dp[1][3][0] = 1,dp[1][4][0] = 0;
		dp[1][1][1] = 0,dp[1][2][1] = 0,dp[1][3][1] = 0,dp[1][4][1] = 0;
	}
	else if(s[1] == 'L'){
		dp[1][1][0] = 0,dp[1][2][0] = 0,dp[1][3][0] = 0,dp[1][4][0] = 0;
		dp[1][1][1] = 0,dp[1][2][1] = 0,dp[1][3][1] = 0,dp[1][4][1] = 1;
	}
	else{
		dp[1][1][0] = 0,dp[1][2][0] = 0,dp[1][3][0] = 0,dp[1][4][0] = 1;
		dp[1][1][1] = 0,dp[1][2][1] = 0,dp[1][3][1] = 0,dp[1][4][1] = 0;
	}
	
	for(int i = 2;i <= n;i++){
		if(s[i] != '_'){
			if(s[i] == 'A'||s[i] == 'E'||s[i] == 'I'||s[i] == 'O'||s[i] == 'U'){
				dp[i][1][0] = dp[i-1][3][0];
				dp[i][2][0] = 0;
				dp[i][3][0] = dp[i-1][2][0]+dp[i-1][4][0];
				dp[i][4][0] = 0;
				dp[i][1][1] = dp[i-1][3][1];
				dp[i][2][1] = 0;
				dp[i][3][1] = dp[i-1][2][1]+dp[i-1][4][1];
				dp[i][4][1] = 0;
			}
			else{
				if(s[i] == 'L'){
					dp[i][1][0] = 0;
					dp[i][2][0] = 0;
					dp[i][3][0] = 0;
					dp[i][4][0] = 0;
					dp[i][1][1] = 0;
					dp[i][2][1] = dp[i-1][4][1]+dp[i-1][4][0];
					dp[i][3][1] = 0;
					dp[i][4][1] = dp[i-1][1][1]+dp[i-1][1][0]+dp[i-1][3][0]+dp[i-1][3][1];
				}
				else{
					dp[i][1][0] = 0;
					dp[i][2][0] = dp[i-1][4][0];
					dp[i][3][0] = 0;
					dp[i][4][0] = dp[i-1][1][0]+dp[i-1][3][0];
					dp[i][1][1] = 0;
					dp[i][2][1] = dp[i-1][4][1];
					dp[i][3][1] = 0;
					dp[i][4][1] = dp[i-1][1][1]+dp[i-1][3][1];
				}
			}	
		}
		else{//j: 1 2y    2 2f    3 y    4 f
			dp[i][1][0] = dp[i-1][3][0]*5;
			dp[i][2][0] = dp[i-1][4][0]*20;
			dp[i][3][0] = dp[i-1][2][0]*5+dp[i-1][4][0]*5;
			dp[i][4][0] = dp[i-1][1][0]*20+dp[i-1][3][0]*20;
			dp[i][1][1] = dp[i-1][3][1]*5;
			dp[i][2][1] = dp[i-1][4][1]*21+dp[i-1][4][0];
			dp[i][3][1] = dp[i-1][2][1]*5+dp[i-1][4][1]*5;
			dp[i][4][1] = dp[i-1][1][1]*21+dp[i-1][3][1]*21+dp[i-1][1][0]+dp[i-1][3][0];
		}
	}
	/*
	for(int i = 1;i <= n;i++){
		for(int j = 1;j <= 4;j++){
			cout<<dp[i][j][0]<<"|"<<dp[i][j][1]<<" ";
		}
		cout<<endl;
	}
	*/
	cout<<dp[n][1][1]+dp[n][2][1]+dp[n][3][1]+dp[n][4][1];
}

B. 解方程

题目描述
考虑以下的方程形式:

\[a * x^2_1+b * x^2_2+c * x^2_3+d * x^2_4 = 0 \]

a,b,c,d是区间[-50,50]内的整数。

求满足以下条件的方程解

\[(x_1,x_2,x_3,x_4) \]

的个数:x是区间[-100,100]内的非零整数。

格式
输入格式
单组输入数据,输入四个整数,表示a,b,c,d

输出格式
输出一个整数,表示解的个数。

Samples
输入数据 1

1 2 3 -4

输出数据 1

39088

输入数据 2

1 1 1 1

输出数据 2

0

数据范围与提示

对于5%的数据,a,b,c,d均为 0;

对于另外10%的数据,a,b,c,d中有 3 个 0 ;

对于另外25%的数据,a,b,c,d中有 2 个 0 ;

对于另外30%的数据,a,b,c,d中有 1个 0 ;

对于剩余30%的数据,无特殊限制 ;

#include<bits/stdc++.h>
using namespace std;
int main()
{
    int a,b,c,d;
    long long count = 0;
    cin >> a >> b >> c >> d;
    for(int x1 = 1;x1 <= 100;x1++)
        for(int x2 = 1;x2 <= 100;x2++)
            for(int x3 = 1;x3 <= 100;x3++)
                for(int x4 = 1;x4 <= 100;x4++)
                    if(a * x1 * x1 + b * x2 * x2 + c * x3 * x3 + d * x4 * x4 == 0) count++;
    cout << count * 16 << endl;
    return 0;
}

不需要过多思考,直接暴力啊。


C. AB数字游戏

题目描述
小C和小T又在玩数字游戏了。这次的规则是这样的:最开始有两个空的数列 A 和 B,第 i 次小T会给数列 A 和 B 分别加上一个数 \(A_i,B_i\),而小C可以将 A 和 B 以任意方式重新排序,使得\(A_i+B_i\) 的最大值最小。

请你帮小C在每一次小T给出两个新的数之后,求出最大值的最小值。

格式
输入格式
第一行包括 1 个正整数 N,表示小T给出数字的次数。

接下来 N 行,第 i+1 行包括 2 个正整数 \(A_i,B_i\),表示每次一小T给出的数对。

输出格式
输出包括 N 行,对于每一次小T 给出的数字,求出所求排列中对应 A 和 B 之和的最大值的最小值。

样例
输入数据 1

3
2 8
3 1
1 4

输出数据 1

10
10
9

输入数据 2

3
1 1
2 2
3 3

输出数据 2

2
3
4

数据范围与提示
对于 50%的数据,有 N≤200,

对于 100%的数据,有 1≤N≤100000,1≤A,B≤100。

第一组样例解释:

第一次询问:A = {2}, B = {8},MIN{Ai + Bi}=2+8=10;

第二次询问:A = {2,3}, B = {8,1},MIN{Ai + Bi}=2+8=10;

第三次询问:A = {1,2,3}, B = {8,1,4},MIN{Ai + Bi}=1+8=9;

//Zn
#include<bits/stdc++.h>
#include<bits/extc++.h>
using namespace std;
using namespace __gnu_pbds;
int n,ta,tb,ans,l,r,tot,t;
int a[110],b[110];
int c[110],d[110];
int main()
{
    ios::sync_with_stdio(0);
    cin>>n;
    for(int i=1;i<=n;i++)
    {
        cin>>ta>>tb;
        a[ta]++;
        b[tb]++;
        ans=0;
        for(int i=1;i<=100;i++)
            c[i]=a[i];
        for(int j=1;j<=100;j++)
            d[j]=b[j];
        l=1;
        r=100;
        tot=0;
        while(tot<i*2)
        {
            while((!c[l])&&l<100) l++;
            while((!d[r])&&r>1) r--;
            t=min(c[l],d[r]);
            ans=max(ans,l+r);
            tot+=t*2;
            c[l]-=t;
            d[r]-=t;
        }
        cout<<ans<<'\n';
    }
    return 0;
}

D. 可交换数字最大连续和

题目描述
一个长度为n 数组 A 的最大连续和,是指所有满足 \(1≤L≤R≤n\) 的 a[i]和的最大值。一次交换操作是指:(1) 选择两个下标 i 和(i∗j)(2) 进行赋值,$tmp=A[i],A[i]=A[j],A[j]=tmp $;

给定一个长度为 n 的数组, 最多进行 m 次交换操作后,该数组的最大连续和。

输入格式
第一行两个两个整数 n和m。

第二行n 个数字,表示数组中的元素。

输出格式
输出答案。

样例
输入数据 1

10 2
10 -1 2 2 2 2 2 2 -1 10

输出数据 1

32

输入数据 2

5 10
-1 -1 -1 -1 -1

输出数据 2

-1

第四题没人解出来。。。。

标签:10,2024.4,输出,int,输入,数据,dp
From: https://www.cnblogs.com/white-ice/p/18119469

相关文章

  • 2024.4.7 向量化编程AVX/NEON
    基本介绍X86:Intelx86是英特尔公司于1978年推出的16位微处理器;而x86泛指一系列基于Intel8086且向后兼容的中央处理器指令集架构IntelICC和开源的GCC编译器支持SSE/AVX指令的C语言接口(intrinsic,内置函数),在intrinsic.h头文件中(头文件可能有所不同)函数命名:第一部分:mm/mm256......
  • 2024.4.6 组合数学补题
    CF128CGameswithRectangle个人认为突破点是“严格包含”,一开始没注意严格不知道怎么处理。严格的话就是横竖分别在若干条边中,分别选出2k条边。横竖互不影响可以乘法原理,只考虑一个方向即可。#include<iostream>#include<cstdio>#include<algorithm>#definemaxn10000......
  • 2024.4.6练习笔记
    浙江理工大学2024年程序设计竞赛(同步赛)Fleetcode题目要求:求出一个序列中对于每个位置\(i\),以\(i\)为起点第一个\(\text{leetcode}\)子序列的终止位置。需要注意的是不要求子序列连续。不存在则答案为零。容易想到双指针,但是会TLE,考虑一些优化。扫描序列,字母是属于......
  • 2024.4.6 - 4.12
    SatJOI2023Final宣传2\(n\)个人,每个人有住所位置\(X_i\)与影响力\(E_i\),一个人\(i\)拿到书后会号召另一个人\(j\)买书仅当\(|X-i-X_j|\leqE_i-E_j\),你最少送多少个人书才能使得所有人都会有书(送的或者被号召买书)。\(n\leq5\times10^5\)。拆一下绝对值,得:\[......
  • 2024.4.5 RMQ补题
    P2048[NOI2010]超级钢琴前缀和处理连续子段的和弦,然后rmq求最大值运用堆存储最优答案每次取出堆头统计一次后,除掉统计点再分成两段加入即可,共k次#include<bits/stdc++.h>#definemaxn500010#defineINF0x3f3f3f3f#defineintlonglongusingnamespacestd;int......
  • 1.5 警惕和揭秘伪创新(1)《软件方法》2024.4更新
    DDD领域驱动设计批评文集做强化自测题获得“软件方法建模师”称号《软件方法》各章合集1.5警惕和揭秘伪创新初中数学里要学习全等三角形、相似三角形、SSS、SAS……,到了高中以后学了正弦定理、余弦定理等解三角形的知识……就不会再回去用初中的方法解题了。但是,不是所......
  • 2024.4 做题记录
    299.CF1534ELostArray难崩。题意转化为每次翻转\(m\)个\(01\)序列的元素,要把全\(0\)翻成全\(1\)。不想分讨。考虑直接最短路求最小步数,转移就枚举选多少个原本已经有的数。交互就记录方案就行了。300.P9537[YsOI2023]CF1764B很棒的题。考察终态,可以发现最后输......
  • 2024.4 第一周做题记录
    \(2024.4.2\)CF1336DYuiandMahjongSet题意:初始有一个值域在\([1,n]\)的多重整数集\(S\),且每个元素重复次数最多为\(n\),定义\(\operatorname{triple}(S)\)表示\(S\)中相同无序三元组数量,\(\operatorname{straight}(S)\)表示\(S\)中连续整数的无序三元组数量,告诉......
  • #19 2024.4.3
    694.pjudge21633【PER#2】2048695.loj3483「USACO2021.2Platinum」CountingGraphs696.loj2468「2018集训队互测Day2」神秘货币史。697.cf1935fAndrey'sTree反思。考虑一个\(mx\rightarrowmx+1\)的构造。那么它挺赢的。考虑一些cornercase,即\(u=mx......
  • 随堂练习2024.4.3
    建立规则,仪式,流程,模式:  定义代码编写和审查的标准,确保开发质量。  实施敏捷开发的仪式,如日常站会,迭代评审和回顾会议,以提高团队协作和项目透明度。 建立清晰的开发流程和里程碑,确保项目按时推进。给好行为正面的反馈:  对于按时完成任务且代码质量高的开发人员......