leet 667.优美的排列

本文介绍了如何在C++中实现优美的排列问题,详细解释了解题思路,包括如何构造序列以及针对奇偶数的不同处理策略。通过示例展示了n=3, k=2时的解决方案,并提供了代码实现。" 124594097,7150756,Android手势检测与滑动速度跟踪:GestureDetector与VelocityTracker实战,"['Android开发', '手势识别', '触摸事件处理']
摘要由CSDN通过智能技术生成

优美的排列

给定两个整数 n 和 k,你需要实现一个数组,这个数组包含从 1 到 n 的 n 个不同整数,同时满足以下条件:

① 如果这个数组是 [a1, a2, a3, … , an] ,那么数组 [|a1 - a2|, |a2 - a3|, |a3 - a4|, … , |an-1 - an|] 中应该有且仅有 k 个不同整数;.

② 如果存在多种答案,你只需实现并返回其中任意一种.

示例 2:

输入: n = 3, k = 2
输出: [1, 3, 2]
解释: [1, 3, 2] 包含 3 个范围在 1-3 的不同整数, 并且 [2, 1] 中有且仅有 2 个不同整数: 1 和 2

解题思路

先来看一个例子:n=6的情况,这个时候k最大只能为5。

排列如下:
在这里插入图片描述

那么我们是怎么得到这个序列的呢?

先在第一位排上最小的数字,我们这里要做5个差,所以在第二位放上最大的那个数,第三位放上除去第一位的最小的数(即第二小的数),第四位放上第二大的数,依次向后可以得到答案。


那么对于n=4得到怎样的队列呢?
在这里插入图片描述

这两种排列有什么不同呢? 看最后两位,n=4的时候是降序,n=5的时候是升序。因为前四位已经构造了三种差值,如果之后只要再构造一种差值那就从第四位(数字5处)开始进行依次降序,差值恒为一。

这只是构造的一种办法,并不是唯一解

怎么知道该从什么处决定是降序还是升序呢?

依然从上面讲起,这里从奇偶来看,对于k=4,前四位采用有三个差值,后面再构造一种即可,因为数字5(第四位)是大值,所以后面降序。对于k=5,前五位有四种差值,再构造一位即可,但是由于数字3(第五位)是下降值,要构造不同的差值,下一位要升序(从当前位开始升序)

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值