C语言设计递归算法生成n个元素组成的集合{r1rn}的子集逐句注释代码
以下是一个使用递归算法生成n个元素组成的集合的所有子集的C语言代码,并且每行都有注释解释其功能:
#include <stdio.h>
// 递归函数,生成所有子集
void generateSubsets(int arr[], int subset[], int n, int index) {
// 基本情况:当index达到数组arr的长度时,打印当前subset并返回
if (index == n) {
printf("{ ");
for (int i = 0; i < n; i++) {
if (subset[i] == 1) {
printf("%d ", arr[i]);
}
}
printf("}\n");
return;
}
// 递归情况1:选择当前元素
subset[index] = 1;
generateSubsets(arr, subset, n, index + 1);
// 递归情况2:不选择当前元素
subset[index] = 0;
generateSubsets(arr, subset, n, index + 1);
}
int main() {
int n;
printf("请输入集合的元素个数:");
scanf("%d", &n);
int arr[n];
printf("请输入集合的元素:");
for (int i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
int subset[n];
generateSubsets(arr, subset, n, 0);
return 0;
}
这个程序使用了递归算法来生成给定集合的所有子集。程序首先接受用户输入的集合元素个数n和元素值,并将它们存储在一个数组arr中。
然后,程序调用generateSubsets函数来生成所有子集。这个函数有四个参数:arr是输入的数组,subset是当前正在构建的子集,n是集合元素个数,index是当前处理的元素索引。
在函数内部,有两个情况需要处理:
- 基本情况:当
index达到数组arr的长度时,说明已经处理完所有元素。此时,打印当前子集,并返回上一层递归。 - 递归情况:分别处理选择当前元素和不选择当前元素的情况。将
subset[index]分别设置为1和0,然后递归调用generateSubsets函数处理下一个元素。
在main函数中,程序接受用户输入的集合元素个数和元素值,并调用generateSubsets函数生成所有子集。最后,程序返回0表示正常结束。
原文地址: https://www.cveoy.top/t/topic/jdWz 著作权归作者所有。请勿转载和采集!