呼伦贝尔寰宇网站建设,网站主机地址,网站建设项目方案模板,深圳室内设计网day10--umi的函数--2.13
习题概述
题目背景
umi 找到了一个神秘的函数 f。
题目描述
这个函数接受两个字符串 s1,s2。这些字符串只能由小写字母组成并且具有相同的长度。这个函数的输出是另一个长度与 s1,s2 相同的字符串 g。
g 的第 i 个字符等于 s1 的第 i 个字符和 s2…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。 代码部分
#includebits/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.要比较每个字符串中的每个字符的大小要用到数组来表示。