- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
在 C++ 中,我使用嵌套的 for 循环来匹配具有相同名称的对象对。我预计该程序需要很长时间才能运行(比较数千个字符串)但是随着它的进行,程序运行得越来越慢。它会在几分钟内比较前 20% 的字符串,但一旦完成大约 30%,就需要将近 60 秒来检查一个字符串与其他字符串。
我的“新数据”包含字段“feas”、“eff”和“numIdeas”的正确值,而我的旧数据与其匹配的"new"合作伙伴共享“数据”字段。新数据和旧数据的顺序不同,我无法对它们进行排序,因为它们当前的顺序很有意义。我认为最好的方法就是“蛮力”通过它。就像我说的,它们没有特定的顺序,所以循环迭代的极度减慢让我感到困惑。据我所知,速度应该保持不变。
for(int i=0; i< newDO.getNumItems(); i++)
{
Item newItem = newDO.getItem(i);
for(int k=0; k < oldDO.getNumItems(); k++)
{
Item oldItem = oldDO.getItem(k);
if(oldItem.getType()==1)
{
bool same = testStrings(oldItem.getData(), newItem.getData());
if(same)
{
oldItem.setFeas(newItem.getFeas());
oldItem.setEff(newItem.getEff());
oldItem.setNumIdeas(newItem.getNumIdeas());
break;
}
}
}
}
我没有编写此 testStrings
函数,但我没有发现它有任何实际问题。此函数获取字符串(大约 5-20 个字符)并去除所有空格和“(”。
(据我所知,我之前的人导入了数千个文件,然后才意识到解析它们的函数没有从某些数据中正确删除“(”,所以他对此的解决方法是忽略它们在检查字符串是否相等时)。
bool testStrings(string s1, string s2)
{
string s1def ="";
for(int i=0; i<s1.length(); i++)
{
if(s1[i]!=' ' || s1[i]!=')'){s1def+=s1[i];}
}
string s2def = "";
for(int i=0; i<s2.length(); i++)
{
if(s2[i]!=' ' || s2[i]!=')'){s2def+=s2[i];}
}
if(s1def == s2def){return true;}
else{return false;}
}
任何见解都会非常有帮助。
谢谢。
最佳答案
这段代码几乎可以用来演示如何做错所有事情。
正如@jahhaj 已经提到的,您似乎在使用二次算法。
您通过在比较函数中去除额外的字符来复合它,因为这意味着您每次进行比较时都会去除额外的字符,而不是预先一次。
如果我这样做,我会先创建一个结构,例如:
struct index {
std::string key;
size_t subscript;
}
您将通过将要比较的字符串复制到 key
并将该项目的下标复制到 subscript
来初始化它。
然后遍历并从这些字符串中删除多余的字符(' ' 和 ')')。然后对这些数组进行排序,只比较 key
字段。然后使用 std::set_intersection
查找公共(public)项。
通过复制和排序键,您将能够在不影响数据(重要的)现有顺序的情况下利用排序。通过预先去除多余的字符,您只需去除每个键一次。通过使用 set::intersection
,您可以得到具有线性复杂度而不是二次复杂度的常见项。
明显的缺点是复制字符串显然会增加您必须存储的数据量。但是,如果项目的数量足够大,足以产生很大差异,那么您也有足够的能力从二次复杂度到线性复杂度将代表巨大时间节省。复制数据是合理的,即使这意味着您必须临时将其他数据写入磁盘。
关于c++循环在每次迭代时变慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11806276/
SQLite、Content provider 和 Shared Preference 之间的所有已知区别。 但我想知道什么时候需要根据情况使用 SQLite 或 Content Provider 或
警告:我正在使用一个我无法完全控制的后端,所以我正在努力解决 Backbone 中的一些注意事项,这些注意事项可能在其他地方更好地解决......不幸的是,我别无选择,只能在这里处理它们! 所以,我的
我一整天都在挣扎。我的预输入搜索表达式与远程 json 数据完美配合。但是当我尝试使用相同的 json 数据作为预取数据时,建议为空。点击第一个标志后,我收到预定义消息“无法找到任何内容...”,结果
我正在制作一个模拟 NHL 选秀彩票的程序,其中屏幕右侧应该有一个 JTextField,并且在左侧绘制弹跳的选秀球。我创建了一个名为 Ball 的类,它实现了 Runnable,并在我的主 Draf
这个问题已经有答案了: How can I calculate a time span in Java and format the output? (18 个回答) 已关闭 9 年前。 这是我的代码
我有一个 ASP.NET Web API 应用程序在我的本地 IIS 实例上运行。 Web 应用程序配置有 CORS。我调用的 Web API 方法类似于: [POST("/API/{foo}/{ba
我将用户输入的时间和日期作为: DatePicker dp = (DatePicker) findViewById(R.id.datePicker); TimePicker tp = (TimePic
放宽“邻居”的标准是否足够,或者是否有其他标准行动可以采取? 最佳答案 如果所有相邻解决方案都是 Tabu,则听起来您的 Tabu 列表的大小太长或您的释放策略太严格。一个好的 Tabu 列表长度是
我正在阅读来自 cppreference 的代码示例: #include #include #include #include template void print_queue(T& q)
我快疯了,我试图理解工具提示的行为,但没有成功。 1. 第一个问题是当我尝试通过插件(按钮 1)在点击事件中使用它时 -> 如果您转到 Fiddle,您会在“内容”内看到该函数' 每次点击都会调用该属
我在功能组件中有以下代码: const [ folder, setFolder ] = useState([]); const folderData = useContext(FolderContex
我在使用预签名网址和 AFNetworking 3.0 从 S3 获取图像时遇到问题。我可以使用 NSMutableURLRequest 和 NSURLSession 获取图像,但是当我使用 AFHT
我正在使用 Oracle ojdbc 12 和 Java 8 处理 Oracle UCP 管理器的问题。当 UCP 池启动失败时,我希望关闭它创建的连接。 当池初始化期间遇到 ORA-02391:超过
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 9 年前。 Improve
引用这个plunker: https://plnkr.co/edit/GWsbdDWVvBYNMqyxzlLY?p=preview 我在 styles.css 文件和 src/app.ts 文件中指定
为什么我的条形这么细?我尝试将宽度设置为 1,它们变得非常厚。我不知道还能尝试什么。默认厚度为 0.8,这是应该的样子吗? import matplotlib.pyplot as plt import
当我编写时,查询按预期执行: SELECT id, day2.count - day1.count AS diff FROM day1 NATURAL JOIN day2; 但我真正想要的是右连接。当
我有以下时间数据: 0 08/01/16 13:07:46,335437 1 18/02/16 08:40:40,565575 2 14/01/16 22:2
一些背景知识 -我的 NodeJS 服务器在端口 3001 上运行,我的 React 应用程序在端口 3000 上运行。我在 React 应用程序 package.json 中设置了一个代理来代理对端
我面临着一个愚蠢的问题。我试图在我的 Angular 应用程序中延迟加载我的图像,我已经尝试过这个2: 但是他们都设置了 src attr 而不是 data-src,我在这里遗漏了什么吗?保留 d
我是一名优秀的程序员,十分优秀!