美文网首页
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