本文主要是介绍洛谷C++简单题小练习day10—umi的函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
day10--umi的函数--2.13
习题概述
题目背景
umi 找到了一个神秘的函数 f。
题目描述
这个函数接受两个字符串 s1,s2。这些字符串只能由小写字母组成并且具有相同的长度。这个函数的输出是另一个长度与 s1,s2 相同的字符串 g。
g 的第 i 个字符等于 s1 的第 i 个字符和 s2 的第 i 个字符的最小值 g[i] = min( s1[i] , s2[i] )
例如:f ("ab","ba") = "aa" f ("nzwzl","zizez") ="niwel"
她现在有两个相同长度的只有小写字母的字符串 x,y。找出任何一个满足 f(x,z)=y 的
字符串 z。如果找不到这样的字符串的话,请输出-1。
输入格式
第一行给出以下两个字符串的长度 n。
第二行给出一个字符串 x。
第三行给出一个字符串 y。
输出格式
第一行输出一个字符串,代表你找到的符合条件的字符串。找不到的话,请输出-1。
代码部分
#include<bits/stdc++.h>
using namespace std;int main() {int n;//字符串的长度
//x,y,z分别用来存储输入的2个字符串及最终输出字符串 string x, y, z;cin >> n;cin >> x >> y;z = x; //初始化 z为 xfor (int i = 0; i < n; i++) {if (x[i] < y[i]) {cout << -1 << endl;return 0;}z[i] = min(x[i], y[i]); //更新 z[i]为 x[i]和y[i]的最小值}cout << z << endl;return 0;
}
心得体会
1.该函数的目标是找到一个字符串 z
,使得 z
的每个字符都是 x
和 y
对应位置字符的最小值。
具体实现如下:
1)首先,从输入中读取字符串的长度 n
,以及字符串 x
和 y
。
2) 将字符串 z
初始化为与 x
相同的值。
3) 使用循环遍历字符串的每个字符,检查 x[i]
和 y[i]
的值。如果 x[i]
小于 y[i]
,则无法找到满足条件的字符串 z
,输出 -1 并结束程序。
4) 如果 x[i]
不小于 y[i]
,将 z[i]
更新为 x[i]
和 y[i]
中的较小值,即满足函数 f(x, z) = y 的字符。
5) 循环结束后,输出字符串 z
,即满足条件的字符串。
2.要比较每个字符串中的每个字符的大小,要用到数组来表示。
这篇关于洛谷C++简单题小练习day10—umi的函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!