- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我知道罗莎琳德挑战有解决方案,但我不希望它们破坏乐趣。我以为我找到了“寻找共享主题”的解决方案,但我的答案始终是错误的。
问题是在给定的工作表中找到最长的公共(public)子字符串,该工作表由以“>”开头的行和下一行组成,直到另一行以“>”开头的行组成一个序列。它是这样的:
>Rosalind_1
GATTACA
>Rosalind_2
TAGACCA
>Rosalind_3
ATACA
大约有一百个 DNA 片段,您需要找到最长的公共(public)子序列。这是我的方法:
rosa = open("rosalind_lcsm.txt","r")
oku = rosa.readlines()
strs=[]
for line in oku:
if line.startswith(">"):
strs.append("kiko")
else:
strs.append(line)
rosa.close()
strs = strs[1:]
joint = "".join(strs)
joint_s = joint.split("kiko")
theOne = joint_s[0]
rest = joint_s[1:]
start=0
end=1
matches=[]
while end < len(theOne):
end+=1
while all(theOne[start:end] in seq for seq in rest):
end+=1
else:
matches.append(theOne[start:end-1])
end+=1
start=end-1
print(max(matches, key=len))
我的策略是:读取文件,将其拆分为序列,选择第一个序列并将其公共(public)部分与其余部分进行比较。我正在检查至少 2 个匹配项,因为序列是由 ATGC 组成的,并且肯定会发生 1 个匹配项。它从一个字符开始,并不断将其扩展 1 个字符,直到匹配中断。然后它获取最后一个匹配位并附加到列表中。然后从停止的地方重新开始。
我的解决方案给出了答案,但它不是正确的答案,而且我无法发现代码中的误导部分。有人可以尝试理解我的方法并给我修复它的建议吗?
最佳答案
我不会说Python,但我认为你通过执行start=end-1
跳过了可能的匹配。您可能需要执行 start=start+1
。
例如,假设您有以下字符串:
GATCAAGAGCAATCAA
您的算法将首先查找 GA 作为公共(public)子串,然后从第三个字符继续查找。但这样你就错过了真正的最长公共(public)子串,ATCAA。
编辑:显然,您还需要与start
一起重新初始化end
。您可以将其设置为 start+1
以始终像您所做的那样从两个字母的字符串开始查找,或者您可以通过从找到的最长匹配的长度开始来优化代码到目前为止。
关于python - 罗莎琳德溶液固定: shared motifs,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48442419/
我的应用程序中有一个滚动窗口,我在其中创建了一个绘图区域小部件。在绘图区,我放置了多张图片。当用户在搜索框中输入有关图像的信息时,相应的图像会突出显示。 我的问题是如何在用户不使用滚动条的情况下让应用
我正在学习 Julia,但在 R 之外的编程经验相对较少。我直接从 rosalind.info 解决这个问题,你可以找到它 here如果您想了解更多详细信息。 我给了两个字符串:一个基序和一个序列,其
我使用以下代码: UIManager.setLookAndFeel("com.sun.java.swing.plaf.motif.MotifLookAndFeel"); 我想覆盖MotifBorder
当用户单击主题窗口(小部件)的关闭框时,如何拦截,以及如何防止 Motif 窗口管理器在单击关闭框时关闭整个调用应用程序(以便我的应用程序可以关闭Motif 应用程序上下文和窗口并继续运行)?我试图通
我想使用 XmCreate{Error|Warning|Info}Dialog 在我的基于 SDL 的应用程序的主窗口打开并且任何程序数据可用之前在屏幕上显示一些消息。我希望打开对话框,打印预期的消息
我知道罗莎琳德挑战有解决方案,但我不希望它们破坏乐趣。我以为我找到了“寻找共享主题”的解决方案,但我的答案始终是错误的。 问题是在给定的工作表中找到最长的公共(public)子字符串,该工作表由以“>
使用 Motif 工具包,我们可以使用 API“XmCreateArrowButton”创建箭头按钮。 现在,当单击箭头按钮时,该按钮将被选中并保持选中状态。箭头按钮周围画有黑色边框。 有没有一种方法
我是 C 和 Linux 中的 GUI 编程的新手,我很难使用它。这似乎是一件相当简单/直接的事情,但我无法通过谷歌搜索找到任何答案。我想为小部件添加背景颜色。 XmNbackground 似乎是我想
我正在处理一个旧的 Motif 应用程序,它需要加载和显示一长串条目(大约 1500 个)。它通过 XtVaCreateManagedWidget() 创建和管理 xmFormWidgetClass
我有一个在 Raspberry Pi 上运行的 Motif 应用程序。出于调试目的,我在我的 PC 上使用 X Windows 服务器,并通过 Putty 使用 SSH 隧道 X。可能还值得注意的是,
我是 Motif 编程的新手,我想使用 UTF-8 编码。 我试过 XtSetLanguageProc (NULL, NULL, NULL); 但是当我在 Motif 中读取文件时(在 6A volu
我对 MOTIF 编程很感兴趣。 一个问题: 在 Motif GUI 编程中,操作会自动转换并通过 Internet 联网到其他客户端,而无需网络编程,这对吗? 命令是否由X11系统和协议(proto
如何创建没有标题栏 的对话框。我想使用创建 motif 对话框/小部件XtVaCreateMangedWidget 和 XtVaCreateWidget 没有标题栏以及如何创建相同的全屏对话框? 最佳
我有一个在 Linux 上运行的基于主题的应用程序。最近我一直在尝试在 motif 应用程序中创建和启动 gtk 对话框。 但是我注意到这两个工具包不兼容。如果我将 gtk 对话框移到基于主题的应用程
任何人都可以看到我做了什么导致了NullPointerException(下面的堆栈跟踪)吗? 面板显示正常: 文本输出 os.name: Windows Vista os.version:
是否可以从 Motif 中的 BulletinBoard 小部件中删除关闭按钮?或者,或者,附加一个回调函数?我知道我可以为顶层小部件执行此操作,但似乎无法为 BulletinBoard 执行此操作。
如何创建没有系统菜单、最小化和最大化框的 Motif 主窗口?我只是无法通过谷歌搜索和阅读文档和教程来找到方法。我相信为 XtVaCreateManagedWindow 使用一些额外的参数应该是可能的
我正在做一个关于将遗留 GUI 程序从 Motif 迁移到 Gtk 的项目。源代码很长(大约 80k 行)。现在我有两个计划: 简单地找到Motif函数和Gtk函数之间的对应关系。然后编写一些脚本来自
我目前正在为 JComboBox 编写自定义 ListCellRenderer。为此,我使用一个系统在 L&F 更改时获取新的渲染器,并将方法委托(delegate)给它。这适用于所有 L&F。但是,
我有一个用 Xt(X Tools Intrinsic 库)编写的名为 XClient 的类,用于设置多套接字连接。这个 XClient 类用于 OSF/Motif GUI 以扩展 XClient(因此
我是一名优秀的程序员,十分优秀!