C程序找到nCr和nPr
在C编程语言中,nCr被称为组合。 nCr 是从 n 个对象的集合中选择 r 个对象,其中对象的顺序并不重要。
nPr 称为排列 。 nPr 是一组“n”个对象中“r”个对象的排列,这些对象应该按顺序或序列排列。
排列和组合公式
求排列的公式以及 C 语言中给定数字的组合如下 –
- nCr = n!/(r!*(n-r)!)
- nPr = n!/(n-r)!.
求 nCr 的逻辑如下 –
result = factorial(n)/(factorial(r)*factorial(n-r));
登录后复制
找到nPr的逻辑如下 −
result = factorial(n)/factorial(n-r);
登录后复制
Example
以下是用于找到给定数字的排列和组合的C程序−
#include
long factorial(int);
long find_ncr(int, int);
long find_npr(int, int);
int main(){
int n, r;
long ncr, npr;
printf(“Enter the value of n and r
“);
scanf(“%d%d”,&n,&r);
ncr = find_ncr(n, r);
npr = find_npr(n, r);
printf(“%dC%d = %ld
“, n, r, ncr);
printf(“%dP%d = %ld
“, n, r, npr);
return 0;
}
long find_ncr(int n, int r) {
long result;
result = factorial(n)/(factorial(r)*factorial(n-r));
return result;
}
long find_npr(int n, int r) {
long result;
result = factorial(n)/factorial(n-r);
return result;
}
long factorial(int n) {
int c;
long result = 1;
for (c = 1; c
推荐阅读
Notepad++ 插件推荐:代码折叠、语法高亮增强工具合集
Emacs Evil 模式:Vim 用户快速上手 Emacs 的过渡方案
Vim 寄存器深度解析:多缓冲区操作与复杂文本处理
Atom 主题切换:Material Design 与扁平化风格对比推荐
Lightly IDE 快捷键:Python 开发者必学的效率提升操作
Xcode 模拟器调试:多设备同步与性能监控技巧
PyCharm 代码格式化:黑魔法工具 Black 与自动规范配置
IntelliJ IDEA Docker 集成:微服务本地调试与镜像构建
VS Code Remote SSH:远程服务器开发环境搭建全流程
Retool 数据库连接:支持 MySQL、PostgreSQL 等多数据源配置