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

53 篇文章 14 订阅
45 篇文章 1 订阅

Algorithm 第六周

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

你现在是棒球比赛记录员。
给定一个字符串列表,每个字符串可以是以下四种类型之一:
1.整数(一轮的得分):直接表示您在本轮中获得的积分数。
2. “+”(一轮的得分):表示本轮获得的得分是前两轮有效 回合得分的总和。
3. “D”(一轮的得分):表示本轮获得的得分是前一轮有效 回合得分的两倍。
4. “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;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值