lddongdong 2021-12-14 22:29 采纳率: 100%
浏览 51
已结题

请问这道“排列”的算法题的代码如何理解呢?

请问这道“排列”的算法题的代码如何理解呢?希望给出每行代码的注释,非常感谢!

img

img

img

#include<cstdio>

int a[1025] = { 0 };

void NextPermutation(int size)
{
    int flag = size - 1;
    int tmp;
    int i;
    while (a[flag - 1] > a[flag] && flag != 0)
    {
        flag--;
    }
    if (flag == 0)
    {
        for (i = 0; i < size; i++)
            a[i] = i + 1;
        return;
    }
    for (i = size - 1; i >= flag; i--)
    {
            if (a[i] > a[flag - 1])
            {
                temp = a[flag - 1];
                a[flag - 1] = a[i];
                a[i] = temp;
                break;
            }
     }
     while (size - 1 > flag)
     {
            temp = a[size - 1];
            a[size - 1] = a[flag];
            a[flag] = temp;
            flag++;
            size--;
     }
}

int main(void)
{ 
    int m, n, k;
    int i;
    scanf("%d", &m);
    while (m)
    {
        scanf("%d%d", &n, &k);
        for(i = 0; i < n; i++)
            scanf("%d", &a[i]);
        for(i = 0; i < k; i++)
            NextPermutation(n);
        for (i = 0;i < n; i++)
            printf("%d", a[i]);
        printf("\n");
        m--;
    }
    return 0;
}


  • 写回答

1条回答 默认 最新

  • 关注
    #include <cstdio>
    int a[1025] = {0};
    void NextPermutation(int size)
    {
        int flag = size - 1; // size为给出的n的值,代表数字位数
        int temp;
        int i;
        while (a[flag - 1] > a[flag] && flag != 0) //从a[n-1]向左寻找,如果a[flag - 1] > a[flag],就将flag自减,这一步对应算法描述中的(2)
        {
            flag--;
        }
    
        if (flag == 0) //如果这个序列已经是递减的,则这个序列的下一个序列是严格递增的,对应算法的(5)
        {
            for (i = 0; i < size; i++)
                a[i] = i + 1;
            return;
        }
    
        for (i = size - 1; i >= flag; i--) //找到a[flag]到a[size-1]中大于a[flag-1]的最小数字,并将其与a[flag-1]互换,对应算法的(3)
        //由于步骤(2),flag之后的元素都能保证为有序,所以找到的第一个符合要求的数字恰好是大于a[flag-1]的最小数字
        {
            if (a[i] > a[flag - 1])
            {
                temp = a[flag - 1];
                a[flag - 1] = a[i];
                a[i] = temp;
                break;
            }
        }
        while (size - 1 > flag)//对剩余部分重新排序,对应算法的(4)
        {
            temp = a[size - 1];
            a[size - 1] = a[flag];
            a[flag] = temp;
            flag++;
            size--;
        }
    }
    int main(void)
    {
        int m, n, k;
        int i;
        scanf("%d", &m);
        while (m)
        {
            scanf("%d%d", &n, &k);
            for (i = 0; i < n; i++)
                scanf("%d", &a[i]); //给定排列中的n个数字,对应算法描述的(1)
            for (i = 0; i < k; i++)
                NextPermutation(n); //通过此函数修改全局数组a
            for (i = 0; i < n; i++)
                printf("%d", a[i]);
            printf("\n");
            m--;
        }
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 12月28日
  • 已采纳回答 12月20日
  • 修改了问题 12月14日
  • 创建了问题 12月14日

悬赏问题

  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解