美文网首页
C语言经典算法 - 求m 元素集合的n 个元素子集的代码

C语言经典算法 - 求m 元素集合的n 个元素子集的代码

作者: 22334 | 来源:发表于2019-03-26 09:50 被阅读0次

    如下内容段是关于C语言经典算法 - 求m 元素集合的n 个元素子集的内容。

    #include <stdio.h>

    #include <stdlib.h>

    #define MAX 20

    int main(void)

    {

      int set[MAX];

      int m, n, position;

      int i;

      printf("输入集合个数m:");

      scanf("%d", &m);

      printf("输入取出元素n:");

      scanf("%d", &n);

      for (i = 0; i < n; i++)

        set[i] = i + 1;

      for (i = 0; i < n; i++)

        printf("%d ", set[i]);

      putchar('n');

      position = n - 1;

      while (1)

      {

        if (set[n - 1] == m)

          position--;

        else

          position = n - 1;

        set[position]++;

        for (i = position + 1; i < n; i++)

          set[i] = set[i - 1] + 1;

        for (i = 0; i < n; i++)

          printf("%d ", set[i]);

        putchar('n');

        if (set[0] >= m - n + 1)

          break;

      }

      return 0;

    }

    相关文章

      网友评论

          本文标题:C语言经典算法 - 求m 元素集合的n 个元素子集的代码

          本文链接:https://www.haomeiwen.com/subject/nibwvqtx.html