- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
考虑带有钢筋和孔的混凝土板单元的以下表示。
我需要一种算法,可以自动将线分布在具有不同孔的任意形状上。
主要限制是:
D
I
,即 y mod I = 0
,其中 y
是线的 Y 坐标。 D/2
更远离一条线最佳答案
我不确定接下来的内容是您想要的 - 我相当确定这不是您的想法 - 但如果听起来合理,您可以尝试一下。
因为距离最多就是d
,并且可以比这更小,乍一看似乎贪婪的算法应该在这里工作。始终放置下一行,以便 (1) 尽可能少地需要,以及 (2) 它们尽可能远离现有行。
假设您有针对此问题的最佳算法,并将下一行放置在距离 a <= d
处。从最后一行。说它的地方b
线。我们的贪心算法肯定不会超过b
行(因为第一个标准是尽可能少地放置),如果放置 b
线,它会将它们放置在距离 c
与 a <= c <= d
,因为它会尽可能地放置线条。
如果贪心算法没有做最优算法所做的事情,它的不同之处在于以下方式之一:
b'
距离线 a'
离开下一步。那么这些线将在距离 a+a'
并且会有 b+b'
总行。但是贪心算法可以通过放置b'
来模拟这种情况下的最优算法。位移线 a+a'
通过选择 c' = (a+a') - c
.自 c > a
和 a' < d
, c' < d
这是一个合法的安置。 k
不必要的行,如果任何位置至少需要 k
线和最远的需要更多,并且选择孔的排列使得(例如)它跨越的距离是d
的倍数。 . (distance, lines)
和
(distance', lines')
, 如果
distance >= distance'
和
lines <= lines'
,第一个位置始终是首选。这建议使用以下算法:
PlaceLines(start, stop)
// if we are close enough to the other edge,
// don't place any more lines.
if start + d >= stop then return ([], 0)
// see how many lines we can place at distance
// d from the last placed lines. no need to
// ever place more lines than this
nmax = min_lines_at_distance(start + d)
// see how that selection pans out by recursively
// seeing how line placement works after choosing
// nmax lines at distance d from the last lines.
optimal = PlaceLines(start + d, stop)
optimal[0] = [d] . optimal[0]
optimal[1] = nmax + optimal[1]
// we only need to try fewer lines, never more
for n = 1 to nmax do
// find the max displacement a from the last placed
// lines where we can place n lines.
a = max_distance_for_lines(start, stop, n)
if a is undefined then continue
// see how that choice pans out by placing
// the rest of the lines
candidate = PlaceLines(start + a, stop)
candidate[0] = [a] . candidate[0]
candidate[1] = n + candidate[1]
// replace the last best placement with the
// one we just tried, if it turned out to be
// better than the last
if candidate[1] < optimal[1] then
optimal = candidate
// return the best placement we found
return optimal
(seq, lines)
的内存来改善到由
(start, stop)
索引的缓存中.这样,我们可以识别何时尝试计算可能已经评估过的分配。我希望我们会有很多这种情况,无论您对问题实例使用粗离散化还是精细离散化。
max_lines_at_distance
和
max_distance_for_lines
函数可能会起作用,但也许就这些而言。
n
和:
f(start, stop, x) = a
和 y < x
, 最多只需要搜索 a
,不是 stop
, 从那时起; f(start, stop, x)
未定义和 y < x
,您无需再搜索。 n
,则此函数可以是未定义的。或更少的行在
start
之间的任何地方和
stop
.
max_lines_at_distance
对于每一行并将其存储在缓存中以备后用。然后,
max_distance_for_lines
可能是一个循环,在两个边界内将缓存从前检查。
关于algorithm - 形状内分布线的优化算法选择,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46808984/
是否有某种方法可以使用 JPA 或 Hibernate Crtiteria API 来表示这种 SQL?或者我应该将其作为 native 执行吗? SELECT A.X FROM (SELECT X,
在查询中, select id,name,feature,marks from (....) 我想删除其 id 在另一个 select 语句中存在的那些。 从 (...) 中选择 id 我是 sql
我想响应用户在 select 元素中选择一个项目。然而这个 jQuery: $('#platypusDropDown').select(function () { alert('You sel
这个问题在这里已经有了答案: SQL select only rows with max value on a column [duplicate] (27 个回答) 关闭8年前。 我正在学习 SQL
This question already has answers here: “Notice: Undefined variable”, “Notice: Undefined index”, and
我在 php 脚本中调用 SQL。有时“DE”中没有值,如果是这种情况我想从“EN”中获取值 应该是这样的,但不是这样的 IF (EXISTS (SELECT epf_application_deta
这可能是一个奇怪的问题,但不知道如何研究它。执行以下查询时: SELECT Foo.col1, Foo.col2, Foo.col3 FROM Foo INNER JOIN Bar ON
如何在使用 Camera.DestinationType.FILE_URI. 时在 phonegap camera API 中同时选择或拾取多个图像我能够一次只选择一张图像。我可以使用 this 在
这是一个纯粹的学术问题。这两个陈述实际上是否相同? IF EXISTS (SELECT TOP 1 1 FROM Table1) SELECT 1 ELSE SELECT 0 相对 IF EXIS
我使用 JSoup 来解析 HTML 响应。我有多个 Div 标签。我必须根据 ID 选择 Div 标签。 我的伪代码是这样的 Document divTag = Jsoup.connect(link
我正在处理一个具有多个选择框的表单。当用户从 selectbox1 中选择一个选项时,我需要 selectbox2 active 的另一个值。同样,当他选择 selectbox2 的另一个值时,我需要
Acme Inc. Christa Woods Charlotte Freeman Jeffrey Walton Ella Hubbard Se
我有一个login.html其中form定义如下: First Initial Plus Last Name : 我的do_authorize如下: "; pri
$.get( 'http://www.ufilme.ro/api/load/maron_online/470', function(data
我有一个下拉列表“磅”、“克”、“千克”和“盎司”。我想要这样一种情况,当我选择 gram 来执行一个函数时,当我在输入字段中输入一个值时,当我选择 pounds 时,我想要另一个函数来执行时我在输入
我有一个 GLSL 着色器,它从输入纹理的 channel 之一(例如 R)读取,然后写入输出纹理中的同一 channel 。该 channel 必须由用户选择。 我现在能想到的就是使用一个 int
我想根据下拉列表中的选定值生成输入文本框。 Options 2 3 4 5 就在这个选择框之后,一些输入字段应该按照选定的数字出现。 最佳答案 我建议您使用响应式(Reac
我是 SQL 新手,我想问一下如何根据首选项和分组选择条目。 +----------+----------+------+ | ENTRY_ID | ROUTE_ID | TYPE | +------
我有以下表结构: CREATE TABLE [dbo].[UTS_USERCLIENT_MAPPING_USER_LIST] ( [MAPPING_ID] [int] IDENTITY(1,1
我在移除不必要的床单时遇到了问题。我查看了不同的论坛并将不同的解决方案混合在一起。 此宏删除工作表(第一张工作表除外)。 Sub wrong() Dim sht As Object Applicati
我是一名优秀的程序员,十分优秀!