- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
以下内容来自 Ruby 2.3.1 文档,该文档根据应用于原始集合中每对元素的特定标准将集合划分为一组子集。基本上,如果集合中的两个数字彼此相差在 1 个单位以内,则它们属于原始集合的子集集合中的同一子集。
require 'set'
numbers = Set[1, 3, 4, 6, 9, 10, 11]
set = numbers.divide { |i,j| (i - j).abs == 1 }
p set # => #<Set: {#<Set: {1}>,
# #<Set: {11, 9, 10}>,
# #<Set: {3, 4}>,
我认为我正在处理的问题可以使用此功能。这就是问题。有一个包含 n 个事物的集合 S 以及 S 中事物对的邻近函数,该集合中的某些事物对具有正值。对于未指定邻近函数值的对,可以假定这些值为 0。还有一个阈值参数。该程序的目标是在集合 S 上引入一个分区(一组成对不相交且相互穷举的集合子集),使得如果两个事物的接近函数值超过阈值参数(相反不一定是真的)。
这个程序的输入是这样的形式
t<-阈值参数(大于0的 float )
n<- 后面的行数(整数)
Thing_i_1 Thing_j_1 proximity_ij_1(Thing_i_1 和 Thing_j_1 是整数,proximity_ij_1 是 float 且大于 0)
........Thing_i_n Thing_j_n proximity_ij_n
输出是前面提到的原始集合的成对不相交且相互穷举的子集集,使得接近函数值至少等于阈值参数的两个事物落入同一子集。
我编写了下面的程序来完成此操作,但它未能形成相关集合的子集。我的输入是这样的
0.2
3
1 2 0.3
3 4 0.1
2 5 0.25
输出应该是 {{1,2,5},{3},{4}} 因为 1,2 应该属于同一个子集,2,5 也应该属于同一个子集,因为每种情况下的邻近函数值都超过了阈值参数(所以 1 和 5 实际上属于同一个子集),而 3 和 4 形成了它们自己的子集。
require 'set'
t=gets.chomp.to_f
n=gets.chomp.to_i
edge=Struct.new(:n1,:n2)
se=Array.new
af=Array.new
sv=Set.new
for i in (0..n-1)
s=gets.chomp.split(" ")
se.insert(-1,edge.new(s[0],s[1]))
af.insert(-1,s[2].to_f)
if (sv.member? s[0])==false
sv.add(s[0])
end
if (sv.member? s[1])==false
sv.add(s[1])
end
end
c=sv.divide { |i,j| (k=se.index(edge.new(i,j)))!=nil && af[k]>=t }
p c
输出:
#<Set: {#<Set: {"5"}>, #<Set: {"2"}>, #<Set: {"1"}>, #<Set: {"3"}>, #<Set: {"4"}
>}>
divide 函数似乎不起作用。我做错了什么吗?为什么我得到五个不相交的子集而不是预期的三个?我在除法 block 中打印出条件值,并准确地得到了 1,2 和 2,5,但 1、2 和 5 最终出现在不同的子集中。有人可以帮忙吗?谢谢。
最佳答案
divide
只会划分block.call(a, b)
&& block.call(b, a)
.让你的se
自反(即也插入边 2-1、4-3 和 5-2),它将起作用。或者,让你的 block 返回 true
如果edge.new(i,j)
或 edge.new(j, i)
在se
.还有一个关于类型的错误:您正在从字符串 ( edge.new(s[0],s[1])
) 创建边缘,但是针对来自整数 ( edge.new(i,j)
) 的边缘进行测试,因此成员资格测试将失败。
也就是说,这是非常不符合 Rubyish 的代码。如果我要重写它,它会是这样的:
require 'set'
Edge = Struct.new(:v1, :v2, :p)
edges = {}
vertices = Set.new
t = gets.chomp.to_f
n = gets.chomp.to_i
n.times do
v1, v2, p = *gets.chomp.split
v1 = v1.to_i
v2 = v2.to_i
p = p.to_f
edge = Edge.new(v1, v2, p)
edges[[v1, v2]] = edge
vertices << v1 << v2
end
c = vertices.divide { |v1, v2|
(edge = edges[[v1, v2]] || edges[[v2, v1]]) && edge.p >= t
}
p c
# => #<Set: {#<Set: {1, 2, 5}>, #<Set: {3}>, #<Set: {4}>}>
基本上 - 使用散列以便您始终可以通过其索引快速找到边缘,使用 <<
对于将事物放入其他事物,请记住集合的全部意义在于它不会两次插入相同的事物,对象是真实的,因此您不必显式测试 != nil
, 从未使用过 for
:)
关于ruby - Ruby 2.3.1 中 set 的除法函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39736038/
我正在尝试编写一个简单的除法函数,但出现错误 PS C:\Users\john> Function Div($x, $y) { $x / $y } PS C:\Users\john> Div (1,
试图找出这个伪代码。以下假设...... 我只能使用无符号和有符号整数(或长整数)。 除法返回一个没有余数的实数。 MOD 返回一个实数。 不处理分数和小数。 INT I = 41828; INT C
如果我有以下表格并且我在关系代数中执行 R1/R2,结果会是一个具有 A 值 1 和 3 的表格吗?我有点困惑,因为我知道 3 将是一个结果,因为它包含 5 和 1,但结果 1 除了匹配的值之外还有
//Declare and intialize variables - programmer to provide initial values Scanner in = new Scanne
除法运算符在 scala BigDecimal 上有什么用? val d1 = BigDecimal(2) val d2 = BigDecimal(3) val div = d1 / d2 //thr
这个问题在这里已经有了答案: How can I divide properly using BigDecimal (2 个答案) 关闭 6 年前。 我在这里做错了什么?很确定这是正确的,我能够打印
好的 - 已经为此苦苦挣扎了一段时间。我刚刚开始学习 Python,所以非常新。 我有一个元组列表,需要按每个元组中值的比率进行排序。 输入: L = [(1,3), (1,7), (4,8)] 返回
我有一个奇怪的问题,我收到计算机生成的方程式(作为字符串),其中偶尔会出现零或一和零的乘法/除法。这些等式将以字符串形式呈现给用户。 我知道我可以通过实现一种解析器来删除等式中的这些冗余部分,但我很好
我有两个变量:count,这是我过滤的对象的数量,以及每页的常量值。我想将计数除以 per_page 并获得整数值,但无论我尝试什么 - 我都得到 0 或 0.0: >>> count = frien
我尝试在 Go 中获得 2.4/0.8 == 3 w:=float64(2.4) fmt.Println(math.Floor(w/0.8),math.Floor(2.4/0.8) ) 它给了我“2
程序清单: # val_caculate.py a = 10 # a是整数 print('10/3 = ',10/3) print('9/3 = ',9/3) pri
我是 java 新手,所以我需要你对我正在进行的项目的帮助!我定义了一些计数器,这些是我将使用的: int[] acceptCounters = {}; int[] acceptFailCounter
我正在除 2 个 BigInteger 值 N = 9440056782685472448790983739834832785827768777249804302814308027414135716
我的应用程序中有使用 array.reduce 将数字相乘的代码。它看起来像这样: // Private function to multiply field values together func
我目前创建了一个名为 Array Math 的类,它将乘法加载到 10x10 数组中,如代码下显示的图像所示,但是我想要做的是在乘法后将每个位置除以 2。换句话说,(行 * 列)/2 目前我只是将这些
我正在使用代表货币金额的 BigDecimal 值。我需要将此金额分成 6 个费率,前 5 个费率四舍五入为 5,其余的为第 6 个费率。 BigDecimal numberOfRates = new
这个问题必须使用递归来解决。 我尝试使用 “else” 之后的代码来使用 int temp 计算商,该 temp 计算可以除以多少次 (temp = dividend - divisor)。 int
我知道这一定是有史以来最简单的事情,但我是这里的初学者。为什么我运行时会出现语法错误 document.write(10 / 2 + ""); //Divide 10 by 5 to get 2
这应该是一个非常基本的东西,但不知何故我没有看到问题。 #include template inline void i2c(const int & ind, int & i, int &j) {
我正在做课本中的一些家庭作业,并且有一些关于某些算术运算的浮点舍入/精度的问题。 如果我像这样从 int 中转换 double : int x = random(); double dx = (dou
我是一名优秀的程序员,十分优秀!