热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

hdoj1521

Problem:1521(排列组合)JudgeStatus:AcceptedRunId:2856508Language:GAuthor:huwenbiaoCodeRenderSta
Problem : 1521 ( 排列组合 )     Judge Status : Accepted
RunId : 2856508    Language : G++    Author : huwenbiao
Code Render Status : Rendered By HDOJ G++ Code Render Version 0.01 Beta

/***************************************************************\
*Author:Hu Wenbiao
*Created Time: Sun 22 Aug 2010 09:47:05 AM CST
*File Name: main.cpp
*Description:组合问题。母函数,其实已经没有了母函数的样子,倒像是一个递推
\***************************************************************/

//*========================*Head File*========================*\\

#include
#include
#include
#include
/*----------------------*Global Variable*----------------------*/
int
m,n,A[
12],B[12],C[12];
//*=======================*Main Program*=======================*//
using namespace std;

int
main(){

//freopen("input","r",stdin);
while(scanf("%d%d",&n,&m)!=EOF){
for
(int i=
1;i<&#61;n;i&#43;&#43;){
scanf(
"%d",A&#43;i);//物品个数
}
memset(B,
0,sizeof(B));
memset(C,
0,sizeof(C));
for
(int i&#61;
1;i<&#61;n;i&#43;&#43;){//第i件物品
for(int j&#61;0;j<&#61;m;j&#43;&#43;){//总个数,指数
if(j!&#61;0&&B[j]&#61;&#61;0)//当B[j]是0时&#xff0c;表示没这种排列&#xff0c;于是便不能
//在此基础上再往下构建新排列了&#xff0c;当然j&#61;&#61;0时是初始状态&#xff0c;应当放行。
continue;
for
(int k&#61;
1;k<&#61;A[i]&&j&#43;k<&#61;m;k&#43;&#43;){//添加的物品个数&#xff0c;(也可以从0开始&#xff0c;下面是赋值)
int method&#61;1;//能构建的排列数
for(int s&#61;1;s<&#61;k;s&#43;&#43;){
method*&#61;(j&#43;s);
method/&#61;s;
}

if
(j)
C[j&#43;k]&#43;&#61;method*B[j];
//每一种能构建method种&#xff0c;共有method*B[j]
else//j&#61;&#61;0时是特例
C[j&#43;k]&#43;&#61;method;
}
}

for
(int j&#61;
0;j<&#61;m;j&#43;&#43;){
B[j]&#43;&#61;C[j];
//此处不是赋值&#xff0c;要加上去(如果上面从0开始&#xff0c;这里就是赋值&#xff09;
C[j]&#61;0;
}
}

printf(
"%d\n",B[m]);
}
}


转:https://www.cnblogs.com/Open_Source/archive/2010/08/22/1904883.html



推荐阅读
  • 丽江客栈选择问题
    本文介绍了一道经典的算法题,题目涉及在丽江河边的n家特色客栈中选择住宿方案。两位游客希望住在色调相同的两家客栈,并在晚上选择一家最低消费不超过p元的咖啡店小聚。我们将详细探讨如何计算满足条件的住宿方案总数。 ... [详细]
  • 本题探讨了在一个有向图中,如何根据特定规则将城市划分为若干个区域,使得每个区域内的城市之间能够相互到达,并且划分的区域数量最少。题目提供了时间限制和内存限制,要求在给定的城市和道路信息下,计算出最少需要划分的区域数量。 ... [详细]
  • 本文深入探讨了HTTP请求和响应对象的使用,详细介绍了如何通过响应对象向客户端发送数据、处理中文乱码问题以及常见的HTTP状态码。此外,还涵盖了文件下载、请求重定向、请求转发等高级功能。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • 本文探讨了在C++中如何有效地清空输入缓冲区,确保程序只处理最近的输入并丢弃多余的输入。我们将介绍一种不阻塞的方法,并提供一个具体的实现方案。 ... [详细]
  • 本问题探讨了在特定条件下排列儿童队伍的方法数量。题目要求计算满足条件的队伍排列总数,并使用递推算法和大数处理技术来解决这一问题。 ... [详细]
  • JSOI2010 蔬菜庆典:树结构中的无限大权值问题
    本文探讨了 JSOI2010 的蔬菜庆典问题,主要关注如何处理非根非叶子节点的无限大权值情况。通过分析根节点及其子树的特性,提出了有效的解决方案,并详细解释了算法的实现过程。 ... [详细]
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • 编程挑战:2019 Nitacm 校赛 D 题 - 雷顿女士与分队(高级版)
    本文深入解析了2019年Nitacm校赛D题——雷顿女士与分队(高级版),详细介绍了问题背景、解题思路及优化方案。 ... [详细]
  • PHP 过滤器详解
    本文深入探讨了 PHP 中的过滤器机制,包括常见的 $_SERVER 变量、filter_has_var() 函数、filter_id() 函数、filter_input() 函数及其数组形式、filter_list() 函数以及 filter_var() 和其数组形式。同时,详细介绍了各种过滤器的用途和用法。 ... [详细]
  • 在现代Web应用中,当用户滚动到页面底部时,自动加载更多内容的功能变得越来越普遍。这种无刷新加载技术不仅提升了用户体验,还优化了页面性能。本文将探讨如何实现这一功能,并介绍一些实际应用案例。 ... [详细]
  • 本文介绍如何在 C++ 中使用链表结构存储和管理数据。通过具体示例,展示了静态链表的基本操作,包括节点的创建、链接及遍历。 ... [详细]
  • 本文详细介绍了C++中map容器的多种删除和交换操作,包括clear、erase、swap、extract和merge方法,并提供了完整的代码示例。 ... [详细]
  • 本文将探讨Java编程语言中对象和类的核心概念,帮助读者更好地理解和应用面向对象编程的思想。通过实际例子和代码演示,我们将揭示如何在Java中定义、创建和使用对象。 ... [详细]
  • 采用IKE方式建立IPsec安全隧道
    一、【组网和实验环境】按如上的接口ip先作配置,再作ipsec的相关配置,配置文本见文章最后本文实验采用的交换机是H3C模拟器,下载地址如 ... [详细]
author-avatar
lrg冰天雪地789_444
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有