赞
踩
给你一个下标从 0 开始的整数数组 nums ,该数组的大小为 n ,请你计算 nums[j] - nums[i] 能求得的 最大差值 ,其中 0 <= i < j < n 且 nums[i] < nums[j] 。
返回 最大差值 。如果不存在满足要求的 i 和 j ,返回 -1 。
示例 1:
输入:nums = [7,1,5,4]
输出:4
解释:
最大差值出现在 i = 1 且 j = 2 时,nums[j] - nums[i] = 5 - 1 = 4 。
注意,尽管 i = 1 且 j = 0 时 ,nums[j] - nums[i] = 7 - 1 = 6 > 4 ,但 i > j 不满足题面要求,所以 6 不是有效的答案。
嵌套for循环依次比较,注意同时满足两个判断条件才开始计算,最后输出最大的值,如果没有就返回-1.
- class Solution {
- public:
- int maximumDifference(vector<int>& nums) {
- int max = -1,arr;
- for (int i = 0; i < nums.size(); i++)
- {
- for (int j = i + 1; j < nums.size(); j++)
- {
- if (nums[i] < nums[j])
- {
- arr = nums[j] - nums[i];
- if (arr > max)
- {
- max = arr;
- }
- }
- }
- }
-
-
- return max;
-
- }
-
- };
给你一个字符串 s ,仅反转字符串中的所有元音字母,并返回结果字符串。
元音字母包括 'a'、'e'、'i'、'o'、'u',且可能以大小写两种形式出现。
示例 1:
输入:s = "hello"
输出:"holle"
遍历字符串,判断遍历到的字符是不是元音字母(aeiou),如果是就记录下来,如果不是就跳过,最后把所有的元音字母逆转顺序。
- class Solution {
- public:
- string reverseVowels(string s) {
- string ans="";
- int len=s.length();
- vector<char> v;
- for(int i=0;i<len;i++){
- if(s[i]=='a'||s[i]=='e'||s[i]=='i'||s[i]=='o'||s[i]=='u'||s[i]=='A'||s[i]=='E'||s[i]=='I'||s[i]=='O'||s[i]=='U'){
- v.push_back(s[i]);
- }
- }
- if(!v.empty()){
- int l=v.size();
- int now=l-1;
- for(int i=0;i<len;i++){
- if(s[i]=='a'||s[i]=='e'||s[i]=='i'||s[i]=='o'||s[i]=='u'||s[i]=='A'||s[i]=='E'||s[i]=='I'||s[i]=='O'||s[i]=='U'){
- ans+=v[now];
- now--;
- }
- else{
- ans+=s[i];
- }
- }
- return ans;
- }
- else{
- return s;
- }
-
-
-
-
-
- }
- };
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。