使用C++编写,找到一个集合上的自反关系的数量

在本文中,我们将解释在一个集合上找到反身关系的方法。在这个问题中,我们给出一个数字n,以及一个由n个自然数组成的集合,我们必须确定反身关系的数量。

反身关系 – 如果对于集合A中的每个’a’,(a, a)属于关系R,则称关系R是集合A上的反身关系。例如 –

Input : x = 1Output : 1Explanation : set = { 1 }, reflexive relations on A * A :{ { 1 } }Input : x = 2Output : 4Explanation : set = { 1,2 }, reflexive relations on A * A :   { ( 1, 1 ) , ( 2, 2 ) }   { ( 1, 1 ), ( 2, 2 ), ( 1, 2 ) }   { ( 1, 1 ), ( 2, 2 ), ( 1, 2 ), ( 2, 1 ) }   { ( 1, 1 ), ( 2, 2 ), ( 2, 1 ) }

登录后复制

因此,如果对于每个元素a ∈ A,都有(a, a) ∈ R,则关系R是自反的。

解决方案的方法

可以通过公式2n2−n来计算元素集上的自反关系的数量。这个通用公式是通过计算整数的自反关系数量得到的。

使用C++编写,找到一个集合上的自反关系的数量

立即学习“C++免费学习笔记(深入)”;

例子

#include using namespace std;int countReflexive(int n){    int ans = 1 > n ; // taking input n from the user using std cin.    int result = countReflexive(n); // calling function to calculate number of reflexive relations    cout 

输出

Number of reflexive relations on set: 1

登录后复制

上述程序的解释

这个程序很容易理解,因为我们只是从用户那里获取输入,并将其放入公式2n2−n中,我们使用左移运算符"

结论

在本文中,我们解决了一个关于集合上反身关系数量的问题。我们讨论了解决给定问题的简单方法,数学家们推导出了一个计算反身关系数量的公式。

我们还学习了用C++编写这个问题的程序,其时间复杂度为O(1)。我们可以用其他语言如C、Java、Python和其他语言编写相同的程序。

以上就是使用C++编写,找到一个集合上的自反关系的数量的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2586747.html

(0)
上一篇 2025年3月6日 15:23:18
下一篇 2025年3月5日 02:42:52

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论