当前位置:   article > 正文

2021-09-26每日刷题打卡_有一个长度为 n,下标从 0 开始的整数数组 v (这个数组是严格递增的)和一个正整数

有一个长度为 n,下标从 0 开始的整数数组 v (这个数组是严格递增的)和一个正整数

5881. 增量元素之间的最大差值

给你一个下标从 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.

  1. class Solution {
  2. public:
  3. int maximumDifference(vector<int>& nums) {
  4. int max = -1,arr;
  5. for (int i = 0; i < nums.size(); i++)
  6. {
  7. for (int j = i + 1; j < nums.size(); j++)
  8. {
  9. if (nums[i] < nums[j])
  10. {
  11. arr = nums[j] - nums[i];
  12. if (arr > max)
  13. {
  14. max = arr;
  15. }
  16. }
  17. }
  18. }
  19. return max;
  20. }
  21. };

345. 反转字符串中的元音字母

给你一个字符串 s ,仅反转字符串中的所有元音字母,并返回结果字符串。

元音字母包括 'a'、'e'、'i'、'o'、'u',且可能以大小写两种形式出现。

示例 1:

输入:s = "hello"
输出:"holle"

遍历字符串,判断遍历到的字符是不是元音字母(aeiou),如果是就记录下来,如果不是就跳过,最后把所有的元音字母逆转顺序。

  1. class Solution {
  2. public:
  3. string reverseVowels(string s) {
  4. string ans="";
  5. int len=s.length();
  6. vector<char> v;
  7. for(int i=0;i<len;i++){
  8. 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'){
  9. v.push_back(s[i]);
  10. }
  11. }
  12. if(!v.empty()){
  13. int l=v.size();
  14. int now=l-1;
  15. for(int i=0;i<len;i++){
  16. 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'){
  17. ans+=v[now];
  18. now--;
  19. }
  20. else{
  21. ans+=s[i];
  22. }
  23. }
  24. return ans;
  25. }
  26. else{
  27. return s;
  28. }
  29. }
  30. };

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/182495?site
推荐阅读
相关标签
  

闽ICP备14008679号