6 寻找比目标字母大的最小字母
作者: Turbo时间限制: 1S章节: 课程设计
问题描述 :
给你一个排序后的字符列表 letters ,列表中只包含小写英文字母。另给出一个目标字母 target,请你寻找在这一有序列表里比目标字母大的最小字母。
在比较时,字母看成是依序循环出现的。即:如果目标字母大于等于letters中最后一个字符,则返回第0个字符。
举个例子:
如果目标字母 target = 'z' ,字符列表为 letters = ['a', 'b'],则答案返回 'a'
示例 1:
输入:
3
c f j
a
输出: c
示例 2:
输入:
3
c f j
c
输出: f
示例 3:
输入:
3
c f j
d
输出: f
输入说明 :
输入三行:
第一行输入一个整数n表示数组的长度。
第二行输入n个小写英文字母表示数组letters的元素。
第三行输入一个小写英文字母表示目标字符target.
提示:
2 <= n <= 10^4
letters[i] 是一个小写字母
letters 按非递减顺序排序
letters 最少包含两个不同的字母
target 是一个小写字母
输出说明 :
输出一个字符表示结果。
输入范例 :
a b c
a
--------------
输出范例 :
b
#include<iostream>
using namespace std;
int main()
{
char arr[100000];
int n = 0;
cin >> n;
for (int i = 0; i < n; i++)
{
cin >> arr[i];
}
char target;
cin >> target;
if (target == arr[n - 1])
{
cout << arr[0];
}
else if (target == arr[0]&&arr[1]!=arr[0])
{
cout << arr[1];
}
else
{
for (int i = 0; i < n; i++)
{
if (arr[i] > target)
{
cout << arr[i];
return 0;
}
}
cout << arr[0];
}
return 0;
}