⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 main.cpp

📁 我做的一些C语言练习题,里面一共有76道题目,主要用到一些计算机常用的算法,如:递归,分治,动态规划,回溯法,AO算法等,除此之外还用到比较多的数学知识,我做了一部分,还有一些暂时还没做出来,大家也帮
💻 CPP
字号:
/**************************************************************************

  49. 有面值为 M..N 的邮票各一枚,共能拼出多少不同的面额。

  *************************************************************************/

#include <stdio.h>

#define N 6

//各种面值的使用情况
int uses_status[N];
//面值
int par_value[N] = {1,2,3,4,5,6};
//各种组合面值
int comb_value[64];
//组合面值数
int counter = 0;

int find(int sum)
{
	int i;
	for(i=0; i<counter; i++)
	{
		if(comb_value[i] == sum)
			return 1;
	}
	return 0;
}

void combine(int k)
{
	if(k == N)
	{
		int i,sum=0;
		for(i=0; i<N; i++)
		{
			if(uses_status[i])
			{
				sum += par_value[i];
			}
		}
		if(!find(sum))
		{
			comb_value[counter++] = sum;
			printf("%d\n",sum);
		}
	}
	else
	{
		//分治
		uses_status[k] = 1;//有该面值
		combine(k+1);
		uses_status[k] = 0;//没有该面值
		combine(k+1);
	}
}

void main()
{
	combine(0);
	printf("一共有%d种面额!\n",counter);
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -