离散题目15(判断是否为传递关系(结构体))

Time Limit: 1000MS Memory Limit: 65536KB
Submit Statistic
Problem Description
给出集合X、X上的关系R,判断关系R是不是传递的。
例如: A={1,2,3} , R={<1,1>,<1,2>,<2,1>,<3,3>,<2,3>,<3,2>, <2,2>,<1,3>,<3,1>} 显然,R具有传递性。
Input
多组输入,每组输入第一行为集合X的元素;第二行为一个整数n ( n > 0 ),代表X上的关系R中序偶的个数;接下来n行用来描述X上的关系R,每行两个数字,表示关系R中的一个序偶。细节参考示例输入。
非空集合X的元素个数不大于500,每个元素的绝对值不大于2^32 - 1。
Output
每组输入对应一行输出,如果关系R具有传递性输出 ”true”,否则输出 ”yes”。
Example Input

1 2 3
9
1 1
2 2
3 3
1 2
2 1
1 3
3 1
2 3
3 2
1 2 3
6
1 1
1 2
3 3
2 3
3 2
2 2
Example Output

true
yes

include <stdio.h>
include <stdlib.h>
include<
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Go语言中,判断结构体是否为空可以通过判断结构体的各个字段是否为空来实现。对于使用`json.Unmarshal`解析后的结构体,你可以通过判断其中的字段是否为其零值来确定结构体是否为空。以下是一个示例代码: ```go package main import ( "encoding/json" "fmt" ) type Person struct { Name string `json:"name"` Age int `json:"age"` Email string `json:"email"` } func IsEmptyStruct(s interface{}) bool { // 将结构体转换为JSON字符串 jsonStr, _ := json.Marshal(s) // 判断JSON字符串是否为空 return string(jsonStr) == "{}" } func main() { // 示例1:空结构体 var p1 Person fmt.Println("Is p1 empty?", IsEmptyStruct(p1)) // 示例2:非空结构体 p2 := Person{Name: "Alice", Age: 30, Email: "[email protected]"} fmt.Println("Is p2 empty?", IsEmptyStruct(p2)) } ``` 在上述代码中,我们定义了一个`Person`结构体,并实现了一个`IsEmptyStruct`函数来判断结构体是否为空。函数内部先将结构体转换为JSON字符串,然后判断该JSON字符串是否为空。如果JSON字符串为空字符串`{}`,则说明结构体为空;否则,结构体不为空。 在示例中,我们分别创建了一个空结构体`p1`和一个非空结构体`p2`,并通过调用`IsEmptyStruct`函数来判断它们是否为空。 请注意,这种方法只能判断结构体中的字段是否为空,不能判断结构体中的嵌套结构体是否为空。如果需要判断嵌套结构体的空值,可以递归地对嵌套结构体进行判断。同时,结构体的零值和空值的定义可能因字段类型的不同而不同,需要根据实际情况进行判断

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值