Leetcode 5147. 递减元素使数组呈锯齿状(148周赛)

探讨了如何通过最少的操作次数将数组转换成锯齿数组,解析了算法思路与实现过程,提供了C++代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

5147. 递减元素使数组呈锯齿状

 显示英文描述 

我的提交返回竞赛

  • 用户通过次数390
  • 用户尝试次数584
  • 通过次数393
  • 提交次数1476
  • 题目难度Easy

给你一个整数数组 nums,每次 操作 会从中选择一个元素并 将该元素的值减少 1

如果符合下列情况之一,则数组 A 就是 锯齿数组

  • 每个偶数索引对应的元素都大于相邻的元素,即 A[0] > A[1] < A[2] > A[3] < A[4] > ...
  • 或者,每个奇数索引对应的元素都大于相邻的元素,即 A[0] < A[1] > A[2] < A[3] > A[4] < ...

返回将数组 nums 转换为锯齿数组所需的最小操作次数。

 

示例 1:

输入:nums = [1,2,3]
输出:2
解释:我们可以把 2 递减到 0,或把 3 递减到 1。

示例 2:

输入:nums = [9,6,1,6,2]
输出:4

提示:

  • 1 <= nums.length <= 1000
  • 1 <= nums[i] <= 1000

        第一此参加周赛,由于以前没见过第2(二叉树)、3(快照数组)这样的题,成绩不是很理想,只答出1、4题,成绩12分,全球排名865/5319.

        第一题相对比较简单,对奇数下角标的向量进行遍历判断,分成两种情况,奇数下角标为高和奇数下角标为低,分别进行判断计算完成需要的次数,最后输出两个计数值最小的即为正确。值得注意的是在判断时要注意对右边的进行数组越界判断!!!

class Solution {
public:
	int movesToMakeZigzag(vector<int>& nums) {
		int count_a = 0, count_b = 0;
		vector<int>num_copy = nums;
		for (int i = 1; i < nums.size(); i=i+2)
		{
			while(nums[i] >= nums[i-1])
			{ 
				nums[i] --;
				count_a++;
				cout << "1111" << endl;
			}
			if (i + 1 < nums.size())
			{
				while (nums[i] >= nums[i + 1])
				{
					nums[i] --;
					count_a++;
					cout << "222" << endl;
				}
			}
			
			while (num_copy[i] <= num_copy[i - 1])
			{
				num_copy[i - 1] --;
				count_b++;
				cout << "3333" << endl;
			}
			if (i + 1 < nums.size())
			{
				while (num_copy[i] <= num_copy[i + 1])
				{
					num_copy[i + 1] --;
					count_b++;
					cout << "444" << endl;
				}
			}
			cout << count_a << "  " << count_b << endl;

		}
		return min(count_a, count_b);
	}
};

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值