首页 > 其他分享 >C - Word Ladder (Toyota Programming Contest 2024#9 (AtCoder Beginner Contest 370))

C - Word Ladder (Toyota Programming Contest 2024#9 (AtCoder Beginner Contest 370))

时间:2024-10-18 19:51:40浏览次数:18  
标签:AtCoder Word cout Contest int 字母 cin 更换 define

题目链接:C - Word Ladder

题目:

样例:

分析:

不要被题目所吓到,一切长题目都是纸老虎。题目大意就是给你两个字符串s和t,一次只能更换一个字母,求s变到t更换的次数,并输出每次更换一个字母后的最小字典序字符串。题意好理解,可以直接暴力,大力出奇迹。但是有没有更好的方法呢?既然问了就说明是有的。最主要的是要搞清每次更换的是哪个字母。我们可以先考虑特殊情况,假设s中的每个字母都是大于等于t中对应的那个字母,如:s=bbb,t=aaa。第一次s=bbb更换有三种情况:abb bab bba 最小的那个是abb。第二次s=abb更换有两种:aab aba 最小的那个是aab。第三次s=aab可直接更换为t=aaa。可看出当s>=t时更换的次序是从左到右依次更换的。同理可知当s中的每个字母都是小于等于t中对应的那个字母时更换的次序是从右到左依次更换的。由特殊到一般,s中字母既有大于还有小于t中对应的字母时,如样例中:s=afwgebrw,t=oarbrenq。s中字母大于t中相应位置的下标为:12367,小于的为:045。而s到t更换的次序为:12367 540,首先是大于的从左往右,然后是小于的从右往左。知道这就好做了。我们可以用一个动态数组记录每次要改变字母的位置,然后改变就好了。当然也可以用双向队列deque来做,从后往前扫描,s中哪个字母>t中对应的字母是时插入队列的头部,小于时插入队列的尾部,这一套下来后可也得出大于的是从左往右的,小于的是从右往左的。话不多说直接上 code

GAME OVER!!!

END!

方法一:直接暴力 

#include<bits/stdc++.h>
#define int long long
#define endl "\n"
using namespace std;

vector<string>ans;
signed main()
{
	ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	string s, t;
	int k; //s和t中不同的字母个数   
	cin >> s >> t;
	int n = s.size();
	while(s != t) {
		k ++;
		string idx(n, 'z');
		for(int i = 0; i < n; i++ ) {
			if(s[i] != t[i]) {
				string tmp = s;
				tmp[i] = t[i];
				idx = min(idx,tmp); //得到字典序最小的那个字符串 
			}
		}
		ans.push_back(idx);         //把每次最小的字符串加入到答案数组中 
		s = idx;                    //把这次修改后的字符串赋值给s 
	}
	cout << k << endl;
	for(auto i : ans)
		cout << i << endl;
	return 0;
}

方法二:记录位置

#include<bits/stdc++.h>
#define int long long
#define endl "\n"
using namespace std;

signed main()
{
	ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	string s, t;
	cin >> s >> t;
	vector<string> ans;
	vector<int> x; //存要改变字母的下标 
	int n = s.size();
	for(int i = 0; i < n; i++ ) {//大于 从左往右 
		if(s[i] > t[i]) x.push_back(i);
	}
	for(int i = n - 1; i >= 0; i-- ) {//小于 从右往左 
		if(s[i] < t[i]) x.push_back(i);
	}
	int k = x.size(); 
	
	for(int i = 0;i < k; i++ ) {
		s[x[i]] = t[x[i]];
		ans.push_back(s);
	}
	cout << k << endl;
	for(auto i : ans) cout << i << endl; 
	return 0;
}

方法三:deque

#include<bits/stdc++.h>
#define int long long
#define endl "\n"
using namespace std;

signed main()
{
	ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	string s, t;
	cin >> s >> t;
	deque<int> x;
	for(int i = s.size() - 1; i >= 0; i --) {//队列从后往前扫描 
		if(s[i] > t[i]) x.push_front(i);     //大于的插入头部 
		if(s[i] < t[i]) x.push_back(i);      //小于的插入尾部 
	}
	int k = x.size();
	cout << k << endl;
	for(auto i : x) {
		s[i] = t[i];
		cout << s << endl;
	}
	return 0;
}

标签:AtCoder,Word,cout,Contest,int,字母,cin,更换,define
From: https://blog.csdn.net/Jeraphael/article/details/142966139

相关文章

  • 适用于 Windows 10 / 11 的 5 个最佳免费 PDF 转 Word 转换器
     PDF转Word转换器PDF文件是共享文档的首选格式,但是,此类文件存在限制,因此难以修改或编辑。因此,您可能会发现自己正在寻找一种将PDF文件转换为Word或其他可编辑格式的方法。市面上有许多不同的PDF转换器,每一种都提供略有不同的功能。本文将介绍您可能需要PDF转换......
  • 手机pdf转word软件有哪些?分享几种好用手机、电脑转换软件
    在日常工作和学习中,我们经常需要将PDF文件转换为Word文档以便于编辑和修改。有的小伙伴身边有电脑,而有的小伙伴手上只有手机,那怎么在手机上将PDF转换成Word呢?下面给大家分享几种PDF转换Word方法软件,手机、电脑都有,一起来看看吧。软件一:迅捷PDF转换器App这是一款功能强大的PD......
  • IEEE全文导入飞书/Word
    IEEE网站右击切换到PlainSource然后公式显示为latex代码加上$$格式F12打开控制台,输入神秘代码(见附件)最终IEEE网站显示效果直接复制到飞书效果:使用沉浸式翻译将IEEE网站翻译成中文:复制到飞书:生成word生成word效果从IEEE复制MathMLCode替换word中无法......
  • PDF秒变Word,你的文档编辑从此开挂!
    在现代办公中,PDF和Word是我们最常接触的两种文件格式。PDF因其良好的兼容性和固定的格式而广受欢迎,但在编辑时却常常让人感到束手无策。而Word则因其强大的编辑功能成为文档处理的首选。那么,如何将PDF转化为Word,让文档编辑更加顺畅呢?使用工具1.打开浏览器,进入工具箱官网。......