stem cells 2022-10-20 21:34 采纳率: 82.5%
浏览 79
已结题

C++ 求skip Permutation题解

我的代码在oj上超时了,请帮我优化代码,使之能过oj。
oj链接https://codeforces.com/gym/103117/problem/K

#include<bits/stdc++.h>

#define N 1000010

using namespace std;

int p[N]={0};
int s[N]={0};

int main()
{
    int n=0,k=0;
    int s1=0,s2=0;
    int f=0;
    scanf("%d%d",&n,&k);
    f=n-1;
    int i=0;
    for (i=0;i<n;++i) s[i]=p[i]=i+1;
    do
    {
        s1=0;
        for (i=0;i<f;++i) if(p[i]+k==p[i+1]) ++s1;
        if (s1>s2)
        {
            for (i=0;i<n;++i) s[i]=p[i];
            s2=s1;
        }
        if (s2==f) break;
    }
    while (next_permutation(p,p+n));
    for (i=0;i<f;++i) printf("%d ",s[i]);
    printf("%d",s[f]);
    return 0;
}
  • 写回答

1条回答 默认 最新

  • X-道至简 2022-10-20 22:15
    关注

    有个思路 比如 n和k输入是7和3
    以 1和2 3为3轮 轮流输出 1 4 7 ,2 5 ,3 6这样可以递推了。 算法是以1到k 轮流加上k来输出,直到n个数输出完。细节可以再疏理一下

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 10月29日
  • 已采纳回答 10月21日
  • 创建了问题 10月20日

悬赏问题

  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?