- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我在尝试编写这些函数时遇到困难。他们工作不正常,不知道我做错了什么。至于 Transitive,我什至无法开始,希望你能提供任何帮助,以及我在我的功能中做错了什么。谢谢。
示例输入:
0 1 2 3 //elements (A)
0 0 //relations (B)
1 1
2 2
3 3
x y z //elements (A)
x y //relations (B)
y z
y y
z z
x y z //elements (A)
x x //relations (B)
y z
x y
z y
x z
y y
z x
y x
z z
1 2 3 4 5 6 7 8 //elements (A)
1 4 //relations (B)
1 7
2 5
2 8
3 6
4 7
5 8
6 6
1 1
2 2
代码:
bool reflexive(int a[], int sizeOfA, int b[], int sizeOfB)
{
bool hold = true;
for(int i=0; i+1<sizeOfB; i+=2)
{
int e = b[i];
int e1 = b[i];
if(pair_is_in_relation(e1, e, b, sizeOfB) == false)
{
if (hold)
{
return false;
break;
}
}
}
if (hold)
cout << "Reflexive - Yes" << endl;
else
cout << "Reflexive - No" << endl;
return hold;
}
bool symmetric(int a[], int sizeOfA, int b[], int sizeOfB)
{
bool hold = true; // set hold to true
for(int i=0; i+1<sizeOfB; i+=2) // for each pair (e,f) in b
{
int e = b[i];
int f = b[i+1];
if(is_in_relation(f, e, b, sizeOfB)) // if pair(e,f) is not in b
{
if(hold) // set hold to false
{
return false;
break;
}
}
}
if(hold) // if hold return true
cout << "Symmetric - Yes" << endl;
else // if hold is false return false
cout << "Symmetric - No" << endl;
}
void antiSymmetric(int b[], int sizeOfB)
{
bool hold = true; // set hold to true
for(int i = 0; i < sizeOfB;) // for each pair (e,f) in b
{
if(hold == false)
{
cout << "AntiSymmetric - No" << endl;
break; //Did not find (e,e) in b
}
for(int j = 0; j < sizeOfB;)
{
if(b[i] == b[j+1] && b[i+1] == b[j]) //If true, then pair(f,e) exists
{
if(b[i+1] != b[i]) //If true, relation is antisymmetric
{
hold = true;
break;
}
else
{
hold = false;
j = j + 2;
}
}
else
{
hold = false;
j = j + 2;
}
}
i = i + 2;
}
if(hold == true)
cout << "AntiSymmetric - Yes" << endl;
}
void transitive(int a[], int sizeOfA, int b[], int sizeOfB)
{
}
int main()
{
char keepGoing = 'y';
while (keepGoing=='y') {
int set1[4] = {0, 1, 2, 3};
int rel1[8] = {0, 0, 1, 1, 2, 2, 3, 3};
cout << "Set 1: " << endl;
reflexive(set1, 3, rel1, 4);
symmetric(set1, 3, rel1, 4);
antiSymmetric(set1, 3, rel1, 4);
cout << endl;
char set2[4] = {'x', 'y', 'z'};
char rel2[8] = {'x', 'y', 'y', 'z', 'y', 'y', 'z', 'z'};
cout << "Set 2: " << endl;
charReflexive(set2, 4, rel2, 8);
charSymmetric(set2, 4, rel2, 8);
charAntiSymmetric(set2, 4, rel2, 8);
cout << endl;
char set3[3] = {'x', 'y', 'z'};
char rel3[18] = {'x', 'x', 'y', 'z', 'x', 'y', 'z', 'y', 'x',
'z', 'y', 'y', 'z', 'x', 'y', 'x', 'z', 'z'};
cout << "Set 3: " << endl;
charReflexive(set3, 3, rel3, 18);
charSymmetric(set3, 3, rel3, 18);
charAntiSymmetric(set3, 3, rel3, 18);
cout << endl;
int set4[8] = {1, 2, 3, 4, 5, 6, 7, 8};
int rel4[20] = {1, 7, 2, 5, 2, 8, 3, 6, 4, 7, 5, 8, 6, 6, 1, 1,
2, 2};
cout << "Set 4: " << endl;
reflexive(set4, 8, rel4, 20);
symmetric(set4, 8, rel4, 20);
antiSymmetric(set4, 8, rel4, 20);
cout << endl << "Would you like to test it again? (y/n): ";
cin >> keepGoing;
}
return 0;
}
最佳答案
我只读过reflexive
,但你需要重新考虑一下。通常,如果 A
中的第一个元素不等于 B
中的第一个元素,它会打印 "Reflexive - No"
并停止。我不认为你一直都这么想。
[编辑] 好吧,现在我们终于确定了 int a[]
和 int b[]
的内容,我必须重新开始。每个人之前的想法都是完全错误的。 (尤其是我,我以前的“自反”确实是对称的,并且错误地解释了输入。)如果您了解 C++ 类/容器,我强烈建议替换 int a[]
和int b[]
类似:
template <class T>
struct relation {
typedef std::pair<T,T> single_relation;
std::set<T> elements;
std::set<single_relation> all_relations;
};
或类似的东西,但那只是我。
reflexive:
set holds to true
for each element e in a
if pair(e,e) is not in b
set holds to false
break
symmetric:
set holds to true
for each pair(e,f) in b
if pair(f,e) is not in b
set holds to false
break
antisymetric:
set holds to true
for each pair(e,f) in b
if pair(f,e) is in b
if f is not e
set holds to false
break
transitive:
set holds to true
for each pair(e,f) in b
for each pair(f,g) in b
if pair(e,g) is not in b
set holds to false
break
if holds is false
break
请注意,只有自反实际上根本需要 a[]
。
演示:
bool pair_is_in_relation(int left, int right, int b[], int sizeOfB)
{
for(int i=0; i+1<sizeOfB; i+=2) {
if (b[i]==left && b[i+1]==right)
return true;
}
return false;
}
bool antiSymmetric(int b[], int sizeOfB)
{
bool holds = true;
for(int i=0; i+1<sizeOfB; i+=2) {
int e = b[i];
int f = b[i+1];
if(pair_is_in_relation(f, e, b, sizeOfB)) {
if (e != f) {
holds = false;
break;
}
}
}
if (holds)
std::cout << "AntiSymmetric - Yes" << endl;
else
std::cout << "AntiSymmetric - No" << endl;
return holds;
}
关于c++ - 如何测试一个集合是否自反、对称、反对称和/或传递?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8155850/
我目前正在对一个 mmorpg 的二进制网络协议(protocol)进行逆向工程。我正在用 java 实现该协议(protocol)。 对于每个数据包类型,我将创建一个表示二进制数据的类。 例如,聊天
我正在尝试围绕现有类编写半透明包装器,我希望它能够模仿其他类的序列化。 例如,给定以下类: class Foo { [JsonConverter(CustomConverter)] s
是否有使用 Jackson 序列化和反序列化枚举集的简单方法? private enum Type { YES, NO } @JacksonXmlProperty(localName = "t
我很想知道当我们反序列化一个对象时会发生什么。 例如,如果我的类对象由许多其他对象组成,对象创建过程如何在反序列化过程中发生 最佳答案 对象是用默认的初始化字段创建的,然后用从串行流中获取的属性值填充
我正在尝试序列化和反序列化(使用 QDataStream 但这与这里无关)一个 enum class变量: enum class Type : char { Trivial, Comp
我不确定这到底有什么问题...它不会为我编译,我将它从 c 翻译成 C++(或尝试)...是的,我是初学者。谢谢! #include #include using namespace std; i
我遇到的问题与此处描述的问题非常相似:Combining type and field serializers case class(id: Option[UUID], otherValue:Stri
我们知道base中的apply()可以对数组的边距应用一个函数,边距应该是行或列。我想将边距扩大到“对角线” 和“反对角线”。结构看起来像 diagApply <- function(x, FUN,
我找到了 JSON serialization and deserialization to objects in Flutter 的例子但是如何使用像这样的人员列表来做到这一点: [ {
我有一个相当大的terms聚合结果,这些结果被加载到下拉列表中以提供filter功能。 可以说,我的下拉列表中有4000多种动物。我的另一个下拉列表有4种动物颜色。 例, animal --> ["d
我需要将 C# (.NET Framework 4.5.2) 中的一个类与 XML 序列化(反序列化),该类具有 string 的字典属性。键和 string[]数组值。我正在使用 Serializa
[已解决]应用给定的解决方案,效果很好! 程序的目的:在用户打开和关闭程序时保存/重新加载以前的数据。 我曾经用一个对象(obj)成功(反)序列化,现在我有两个不同类的不同对象。 我试图通过查看其他帖
问题 假设我有一个代表某事或其他的枚举: public enum ResultState { Found, Deleted, NotFound } 在我的序列化 json 中,
是否有取消 JSON 字符串的功能?我猜它不会内置到 JQuery 中,但它可以通过编写一个操纵字符串的脚本来实现吗?我在下面遇到了这个问题。 我正在使用 NYTimes API,但它不支持 JSON
对于这个问题,假设当对象完全写入流并成功读出时,或者当对象部分写入流并且读回对象时发生异常时,序列化/反序列化是原子的。假设写操作可能无法成功完成,例如因为停电了。 在Serializable的描述中
有谁知道时序检查是否仍在检测虚拟环境?我尝试使用 rdtsc 指令来获取 cpu 周期并比较真实 linux 机器和在 virtualbox 上运行的 linux 之间的结果。但结果似乎不稳定。有时,
我正在对一个(外部给定的)XML 文件进行操作,该文件具有以下形式的元素 10 20 30 40 50 60 70 80 我知道如何将属性作为属性处理(通过使用 [XmlAttri
我有一个通用的序列化器和反序列化器,用于通过网络连接发送的消息: public static async Task SerializeObject(Object obj) {
我正在考虑将当前基于 WCF 的应用程序迁移到 protobuf-net.Grpc。这似乎是可行的,但是我无法在不包含所有具有 [ProtoInclude] 属性的派生类的情况下使(DTO 类)基类的
我正在尝试将一些数据保存到文件中,但文件保存到的目录不正确。 using (StreamWriter sw = new StreamWriter(dir + "\\temp" + x + ".txt"
我是一名优秀的程序员,十分优秀!