给定两个整数N和M ,任务是计算可以用N个顶点和M个边绘制的简单无向图的数量。简单图是不包含多个边和自环的图。
例子:
Input: N = 3, M = 1
Output: 3
The 3 graphs are {1-2, 3}, {2-3, 1}, {1-3, 2}.
Input: N = 5, M = 1
Output: 10
方法: N个顶点从1到N编号。由于没有自环或多个边,因此该边必须存在于两个不同的顶点之间。因此,我们可以选择两个不同顶点的方式是N C 2 ,它等于(N *(N – 1))/ 2 。假设它为P。
现在必须将M个边与这对顶点一起使用,因此在P对之间选择M对顶点的方式将为P C M。
如果P
下面是上述方法的实现:
C++
// C++ implementation of the approach
#include
using namespace std;
// Function to return the value of
// Binomial Coefficient C(n, k)
int binomialCoeff(int n, int k)
{
if (k > n)
return 0;
int res = 1;
// Since C(n, k) = C(n, n-k)
if (k > n - k)
k = n - k;
// Calculate the value of
// [n * (n - 1) *---* (n - k + 1)] / [k * (k - 1) * ... * 1]
for (int i = 0; i < k; ++i) {
res *= (n - i);
res /= (i + 1);
}
return res;
}
// Driver Code
int main()
{
int N = 5, M = 1;
int P = (N * (N - 1)) / 2;
cout << binomialCoeff(P, M);
return 0;
}
Java
// Java implementation of the approach
class GFG
{
// Function to return the value of
// Binomial Coefficient C(n, k)
static int binomialCoeff(int n, int k)
{
if (k > n)
return 0;
int res = 1;
// Since C(n, k) = C(n, n-k)
if (k > n - k)
k = n - k;
// Calculate the value of
// [n * (n - 1) *---* (n - k + 1)] /
// [k * (k - 1) * ... * 1]
for (int i = 0; i < k; ++i)
{
res *= (n - i);
res /= (i + 1);
}
return res;
}
// Driver Code
public static void main(String[] args)
{
int N = 5, M = 1;
int P = (N * (N - 1)) / 2;
System.out.println(binomialCoeff(P, M));
}
}
// This code is contributed by Shivi_Aggarwal
Python 3
# Python 3 implementation of the approach
# Function to return the value of
# Binomial Coefficient C(n, k)
def binomialCoeff(n, k):
if (k > n):
return 0
res = 1
# Since C(n, k) = C(n, n-k)
if (k > n - k):
k = n - k
# Calculate the value of
# [n * (n - 1) *---* (n - k + 1)] /
# [k * (k - 1) * ... * 1]
for i in range( k):
res *= (n - i)
res //= (i + 1)
return res
# Driver Code
if __name__=="__main__":
N = 5
M = 1
P = (N * (N - 1)) // 2
print(binomialCoeff(P, M))
# This code is contributed by ita_c
C#
// C# implementation of the approach
using System;
class GFG
{
// Function to return the value of
// Binomial Coefficient C(n, k)
static int binomialCoeff(int n, int k)
{
if (k > n)
return 0;
int res = 1;
// Since C(n, k) = C(n, n-k)
if (k > n - k)
k = n - k;
// Calculate the value of
// [n * (n - 1) *---* (n - k + 1)] /
// [k * (k - 1) * ... * 1]
for (int i = 0; i < k; ++i)
{
res *= (n - i);
res /= (i + 1);
}
return res;
}
// Driver Code
public static void Main()
{
int N = 5, M = 1;
int P = (N * (N - 1)) / 2;
Console.Write(binomialCoeff(P, M));
}
}
// This code is contributed
// by Akanksha Rai
PHP
$n)
return 0;
$res = 1;
// Since C(n, k) = C(n, n-k)
if ($k > $n - $k)
$k = $n - $k;
// Calculate the value of
// [n * (n - 1) *---* (n - k + 1)] /
// [k * (k - 1) * ... * 1]
for ($i = 0; $i < $k; ++$i)
{
$res *= ($n - $i);
$res /= ($i + 1);
}
return $res;
}
// Driver Code
$N = 5;
$M = 1;
$P = floor(($N * ($N - 1)) / 2);
echo binomialCoeff($P, $M);
// This code is contributed by Ryuga
?>
输出:
10