Who can help me?
原题链接:36.优秀的拆分2024-05-20 18:56:04
发布于:广东
#include <bits/stdc++.h>
using namespace std;
const int N=0x3f3f3f;
int b[N];
int main()
{
int a;
scanf("%d",&a);
int k=a,a1=a,j=0;
while(true)
{
if(a1<0)
{
break;
}
if(2^k<a1)
{
a1=a1-2^k;
b[j]=k;
j++;
}
}
for(int i=0;i<j;i++)
{
cout<<b[i]<<" ";
}
}
/*这是一个很有趣的题目,涉及到的主要概念是位运算和枚举。首先,让我们一起理解题目的核心要求:
1.我们需要找到正整数n的所有可能拆分。
2.拆分必须由不同的2的正整数次幂组成。
3.如果存在这样的优秀拆分,我们需要按降序输出这些次幂;否则,输出 -1。
为了找到这样的拆分,我们可以采用以下步骤来引导你的解题思路:
步骤1:了解2的正整数次幂
首先,你需要熟悉2的正整数次幂的性质。这些是构成优秀拆分的基本单元。
步骤2:枚举次幂
从最大的 2 的正整数次幂开始,尝试将其次幂之和大于等于 n。在每次减小次幂时,检查当前次幂是否已经被使用过,如果未使用过,则将其添加到拆分列表中,并从 n 中减去该次幂的值。
步骤3:判断优秀拆分
检查拆分列表是否包含不同的 2 的正整数次幂。如果包含,那么找到了一个优秀的拆分;否则,没有找到。
步骤4:输出结果
如果找到优秀拆分,按照降序输出拆分列表;如果找不到,输出 -1。
实现注意事项
使用动态规划或递归的方法来实现枚举过程。
避免重复添加 2 的次幂,可以通过记录已使用的次幂或者使用位运算来优化。
在检查优秀拆分时,确保所有的次幂都是不同的。
现在,你可以尝试根据这些步骤编写代码,并针对样例和其他边界情况测试你的实现。如果遇到困难,可以再次向我询问具体细节,但请尽量自己先思考解决方案。这样有助于提高你的解题能力。祝你好运!*/
这上面的是AC狗的思路,谁能帮帮我,我看不懂……
图片从下往上看
谁能帮我!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
全部评论 1
其实就是一个一个暴力尝试。把一个数字转换成二进制(位运算),然后判断最低位是否为1,如果是的话输出-1。否则的话把每一位代表的值都输出即可。
2024-05-21 来自 新加坡
0o!
2024-05-21 来自 广东
0茅塞顿开
2024-05-21 来自 广东
0
有帮助,赞一个