LeetCode 682. Baseball Game + 496. Next Greater Element I

Algorithm 第六周

LeetCode 682. Baseball Game 题目链接 解题语言 C

你现在是棒球比赛记录员。
给定一个字符串列表,每个字符串可以是以下四种类型之一:
1.整数(一轮的得分):直接表示您在本轮中获得的积分数。

  1. "+"(一轮的得分):表示本轮获得的得分是前两轮有效 回合得分的总和。
  2. "D"(一轮的得分):表示本轮获得的得分是前一轮有效 回合得分的两倍。
  3. "C"(一个操作,这不是一个回合的分数):表示您获得的最后一个有效 回合的分数是无效的,应该被移除。

每一轮的操作都是永久性的,可能会对前一轮和后一轮产生影响。
你需要返回你在所有回合中得分的总和。

示例 1:

输入: ["5","2","C","D","+"]
输出: 30
解释:
第1轮:你可以得到5分。总和是:5。
第2轮:你可以得到2分。总和是:7。
操作1:第2轮的数据无效。总和是:5。
第3轮:你可以得到10分(第2轮的数据已被删除)。总数是:15。
第4轮:你可以得到5 + 10 = 15分。总数是:30。

参考代码
解题思路 :每次操作的数字由数组 stack 存储 ,按照栈的思想每次从栈顶出栈 ,栈顶入栈。

int calPoints(char** ops, int opsSize) {
    int sum = 0, temp;
    int stack[opsSize];//C99 变长数组
    int *p =stack;//定义指针指向数组的第一个元素
    for (int i = 0; i < opsSize; i++, ops++)
    {
        switch (**ops)//**ops 表示的是指针所指向的字符数组的第一个字母
        {
        case '+':
            temp = *p;
            p--;
            temp += *p;
            sum += temp;
            p += 2;
            *p = temp;
            break;
        case 'D':
            temp = *p;
            temp *= 2;
            sum += temp;
            p++;
            *p = temp;
            break;
        case'C':
            temp = *p;
            sum -= temp;
            p--;
            break;
        default:
            temp = atoi(*ops);//将字符串转化成数字 ,需要引入库 stblib.h
            sum += temp;
            p++;
            *p = temp;
            break;
        }
    }
    return sum;
}

LeetCode 496. Next Greater Element I 题目链接 解题语言 C

给定两个没有重复元素的数组 nums1 和 nums2 ,其中nums1 是 nums2 的子集。找到 nums1 中每个元素在 nums2 中的下一个比其大的值。
nums1 中数字 x 的下一个更大元素是指 x 在 nums2 中对应位置的右边的第一个比 x 大的元素。如果不存在,对应位置输出-1。

示例 1:
输入: nums1 = [4,1,2], nums2 = [1,3,4,2].
输出: [-1,3,-1]
解释:
对于num1中的数字4,你无法在第二个数组中找到下一个更大的数字,因此输出 -1。
对于num1中的数字1,第二个数组中数字1右边的下一个较大数字是 3。
对于num1中的数字2,第二个数组中没有下一个更大的数字,因此输出 -1。

优化思路 :将不必要的循环嵌套拆开 ,减少内存消耗
优化后代码

int* nextGreaterElement(int* findNums, int findNumsSize, int* nums, int numsSize, int* returnSize) {
    int* p = (int *)malloc(sizeof(int)*findNumsSize);
    *returnSize = findNumsSize;
    int i = 0, j = 0;
    while (i < findNumsSize)
    {
        j = 0;
        int flag = 0;
        while (*(nums + j) != *(findNums + i))//找到子集元素在合集中的索引
        {
            j++;
        }
        for (; j < numsSize; j++)
        {
            if (*(nums + j)>*(findNums + i))//找到元素右边第一个更大元素时结束循环
            {
                *(p + i) = *(nums + j); flag = 1;
                break;
            }
        }
        if (flag == 0)//如果没有找到更大素 ,则设为 -1
            *(p + i) = -1;
        i++;
    }
    return p;
}

优化前代码

/**
* Return an array of size *returnSize.
* Note: The returned array must be malloced, assume caller calls free().
*/
int* nextGreaterElement(int* findNums, int findNumsSize, int* nums, int numsSize, int* returnSize) {
    int* p = (int *)malloc(sizeof(int)*findNumsSize);
    *returnSize = findNumsSize;
    for (int i = 0; i < findNumsSize; i++)
    {
        for (int j = 0; j < numsSize; j++)
        {
            int flag = 0;
            if (*(findNums + i) == *(nums + j))
            {
                for (int k = j; k < numsSize; k++)
                {
                    if (*(nums + k) >*(nums + j))
                    {
                        //printf("%d  ", *(nums + k));
                        *(p + i) = *(nums + k); flag = 1;
                        break;
                        
                    }   
                }   
                if (flag == 0)
                    *(p + i) = -1;
            }
            
        }
    }
    return p;
}

你可能感兴趣的:(LeetCode 682. Baseball Game + 496. Next Greater Element I)