- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
> wrap("This is the firs-6ren">
我有一个程序可以递归地计算一个自动换行到指定的行长度。
def wrap(input, lineSpaces):
if len(input) <= lineSpaces: # Base case
return input
temp = input.rfind(" ", 0, lineSpaces - 1) # Parsing
if temp == -1:
return input
else:
prev = input[:temp+1]
next = wrap(input[temp+1:], lineSpaces)
wrap.penalty = (lineSpaces-len(prev)+1)**3 +(lineSpaces-len(next)+1)**3 # Penalty calculation
return prev+'\n'+next
# I/O
list = []
penalties = []
M = int(raw_input())
for i in xrange(0, M):
lineSpaces = int(raw_input())
input = raw_input()
list.append(wrap(input, lineSpaces))
penalties.append(wrap.penalty)
for i in xrange(0, len(list)):
print "penalty: ", penalties[i]
print list[i]+"\n"
使用以下输入:
3
20
This is the first paragraph that you need to print
30
This is another paragraph that you need to print and it ends in a very long word onetwothreefourfivesixseven
36
This paragraph all fits on one line
我期望输出:
penalty: 35
This is the first
paragraph that you
need to print
penalty: 216
This is another paragraph
that you need to print and
it ends in a very long word
onetwothreefourfivesixseven
penalty: 0
This paragraph all fits on one line
但是,我实际上得到了输出:
penalty: -1701
This is the first
paragraph that you
need to print
penalty: -148752
This is another paragraph
that you need to print and
it ends in a very long word
onetwothreefourfivesixseven
penalty: -148752
This paragraph all fits on one line
如您所见,我的惩罚输出是错误的。我想将我的惩罚计算为每个段落中所有行的 (lineSpaces-len(line)+1)**3
的总和,每个段落的最后一行除外,该行的惩罚为0. 似乎每次调用 (lineSpaces-len(prev)+1)**3
的每个段落(除了最后一个,它应该是 0)都会返回正确的值。我的逻辑有什么问题?
最佳答案
您对罚款的计算在某些方面是错误的。首先,将 next
设置为递归调用的返回值。这仍然和原来的一样长,或者更长,因为你所做的只是给它添加换行符。但是你计算这个惩罚。在每次调用中,您都在计算该调用适合一行的惩罚与传递给下一个递归调用的所有其他内容的惩罚。
此外,因为您将此值存储在 wrap.penalty
中,所以每次调用后都会覆盖它。由于您从未对 wrap.penalty
的旧值执行任何操作,因此您忽略了除最后一个计算之外的所有计算。
像这样使用函数属性来存储数据是一种危险的游戏。只有一个 wrap
,所以只有一个wrap.penalty
,所以并不是每个递归调用都有自己的版本惩罚
;他们都在踩同一个。与其将值存储在 wrap.penalty
中,不如将其与包装文本一起返回,如下所示:
def wrap(instr, lineSpaces):
if len(instr) <= lineSpaces: # Base case
return instr, 0
temp = instr.rfind(" ", 0, lineSpaces - 1) # Parsing
if temp == -1:
return instr, 0
else:
prev = instr[:temp+1]
next, penalty = wrap(instr[temp+1:], lineSpaces)
penalty += (lineSpaces-len(prev)+1)**3 # Penalty calculation
return prev+'\n'+next, penalty
然后:
>>> wrap("This is the first paragraph that you need to print", 20)
('This is the first \nparagraph that you \nneed to print', 35)
在每次调用时,我将从递归调用返回的惩罚添加到为我刚刚解析的行计算的惩罚中。正如 Pham Trung 在评论中所建议的那样,您也可以在包装后的单独步骤中计算罚金。
我还将您的变量名从 input
更改为 instr
。你应该避免使用名称 input
因为有一个内置函数就是这个名字。 (出于同样的原因,list
也不是一个好的变量名。)
关于python - 需要帮助设计解决方案来计算自动换行函数的 "penalty",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24030274/
我正在尝试用 C 语言编写一个使用 gstreamer 的 GTK+ 应用程序。 GTK+ 需要 gtk_main() 来执行。 gstreamer 需要 g_main_loop_run() 来执行。
我已经使用 apt-get 安装了 opencv。我得到了以下版本的opencv2,它工作正常: rover@rover_pi:/usr/lib/arm-linux-gnueabihf $ pytho
我有一个看起来像这样的 View 层次结构(基于其他答案和 Apple 的使用 UIScrollView 的高级 AutoLayout 指南): ScrollView 所需的2 个步骤是: 为 Scr
我尝试安装 udev。 udev 在 ./configure 期间给我一个错误 --exists: command not found configure: error: pkg-config and
我正在使用 SQLite 3。我有一个表,forums,有 150 行,还有一个表,posts,有大约 440 万行。每个帖子都属于一个论坛。 我想从每个论坛中选择最新帖子的时间戳。如果我使用 SEL
使用 go 和以下包: github.com/julienschmidt/httprouter github.com/shwoodard/jsonapi gopkg.in/mgo.v2/bson
The database仅包含 2 个表: 钱包(100 万行) 事务(1500 万行) CockroachDB 19.2.6 在 3 台 Ubuntu 机器上运行 每个 2vCPU 每个 8GB R
我很难理解为什么在下面的代码中直接调用 std::swap() 会导致编译错误,而使用 std::iter_swap 编译却没有任何错误. 来自 iter_swap() versus swap() -
我有一个非常简单的 SELECT *用 WHERE NOT EXISTS 查询条款。 SELECT * FROM "BMAN_TP3"."TT_SPLDR_55E63A28_59358" SELECT
我试图按部分组织我的 .css 文件,我需要从任何文件访问文件组中的任何类。在 Less 中,我可以毫无问题地创建一个包含所有文件导入的主文件,并且每个文件都导入主文件,但在 Sass 中,我收到一个
Microsoft.AspNet.SignalR.Redis 和 StackExchange.Redis.Extensions.Core 在同一个项目中使用。前者需要StackExchange.Red
这个问题在这里已经有了答案: Updating from Rails 4.0 to 4.1 gives sass-rails railties version conflicts (4 个答案) 关
我们有一些使用 Azure DevOps 发布管道部署到的现场服务器。我们已经使用这些发布管道几个月了,没有出现任何问题。今天,我们在下载该项目的工件时开始出现身份验证错误。 部署组中的节点显示在线,
Tip: instead of creating indexes here, run queries in your code – if you're missing any indexes, you
你能解释一下 Elm 下一个声明中的意思吗? (=>) = (,) 我在 Elm architecture tutorial 的例子中找到了它 最佳答案 这是中缀符号。实际上,这定义了一个函数 (=>
我需要一个 .NET 程序集查看器,它可以显示低级详细信息,例如元数据表内容等。 最佳答案 ildasm 是 IL 反汇编程序,具有低级托管元数据 token 信息。安装 Visual Studio
我有两个列表要在 Excel 中进行比较。这是一个很长的列表,我需要一个 excel 函数或 vba 代码来执行此操作。我已经没有想法了,因此转向你: **Old List** A
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想要改善这个问题吗?更新问题,以便将其作为on-topi
我正在学习 xml 和 xml 处理。我无法很好地理解命名空间的存在。 我了解到命名空间帮助我们在 xml 中分离相同命名的元素。我们不能通过具有相同名称的属性来区分元素吗?为什么命名空间很重要或需要
我搜索了 Azure 文档、各种社区论坛和 google,但没有找到关于需要在公司防火墙上打开哪些端口以允许 Azure 所有组件(blob、sql、compute、bus、publish)的简洁声明
我是一名优秀的程序员,十分优秀!