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;
- }