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日

悬赏问题

  • ¥15 msix packaging tool打包问题
  • ¥28 微信小程序开发页面布局没问题,真机调试的时候页面布局就乱了
  • ¥15 python的qt5界面
  • ¥15 无线电能传输系统MATLAB仿真问题
  • ¥50 如何用脚本实现输入法的热键设置
  • ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
  • ¥30 深度学习,前后端连接
  • ¥15 孟德尔随机化结果不一致
  • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
  • ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线