- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我希望将 c# 方法重构为 c 函数以尝试获得一些速度,然后在 c# 中调用 c dll 以允许我的程序使用该功能。
目前,c# 方法采用整数列表并返回整数列表的列表。该方法计算整数的幂集,因此输入 3 个整数将产生以下输出(在此阶段,整数的值并不重要,因为它用作内部权重值)
1
2
3
1,2
1,3
2,3
1,2,3
其中每一行代表一个整数列表。输出指示第一个列表的索引(偏移量为 1),而不是值。所以 1,2 表示索引 0 和 1 处的元素是幂集的元素。
我不熟悉 c,那么允许 c# 访问返回数据的数据结构的最佳选择是什么?
提前致谢
更新
谢谢大家到目前为止的评论。这是问题性质的一些背景知识。
计算集合的幂集的迭代方法相当简单。两个循环和一点位操作就是它真正的全部。它只是被调用..很多(如果集合的大小足够大,实际上会调用数十亿次)。
我对使用 c(正如人们指出的 c++)的想法是,它为性能调整提供了更大的空间。直接端口可能不会提供任何增加,但它为更多涉及的方法开辟了道路,以从中获得更快的速度。即使每次迭代的小幅增加也等同于可衡量的增加。
我的想法是移植一个直接版本,然后努力增加它。然后随着时间的推移重构它(在 SO 的每个人的帮助下)。
更新 2
jalf 的另一个公平点,我不必使用 list 或 equivelent。如果有更好的方法,那么我愿意接受建议。该列表的唯一原因是每组结果的大小不同。
到目前为止的代码...
public List<List<int>> powerset(List<int> currentGroupList)
{
_currentGroupList = currentGroupList;
int max;
int count;
//Count the objects in the group
count = _currentGroupList.Count;
max = (int)Math.Pow(2, count);
//outer loop
for (int i = 0; i < max; i++)
{
_currentSet = new List<int>();
//inner loop
for (int j = 0; j < count; j++)
{
if ((i & (1 << j)) == 0)
{
_currentSetList.Add(_currentGroupList.ElementAt(j));
}
}
outputList.Add(_currentSetList);
}
return outputList;
}
如您所见,并不多。它只是转来转去很多!
我承认创建和构建列表可能不是最有效的方式,但我需要某种方式以可管理的方式返回结果。
更新 2
感谢所有的输入和实现工作。只是为了澄清提出的几点:我不需要输出是“自然顺序”的,而且我对返回的空集也不感兴趣。
hughdbrown 的实现正在测试中,但我认为我需要在某个时候存储结果(或至少其中的一个子集)。听起来内存限制会在运行时间成为一个真正的问题之前很久就适用。部分原因在于,我认为我可以使用字节而不是整数,从而提供更多潜在存储空间。
真正的问题是:我们是否达到了 C# 中此计算的最大速度?非托管代码选项是否提供更多范围。我知道在很多方面答案都是徒劳的,因为即使我们有时间运行,它也只会允许原始集合中的额外值。
最佳答案
此外,请确保迁移到 C/C++ 确实是您开始提高速度所需要做的事情。检测原始 C# 方法(独立的,通过单元测试执行),检测新的 C/C++ 方法(同样,通过单元测试独立的),看看现实世界的区别是什么。
我之所以提出这个问题,是因为我担心这可能是一个失败的胜利——使用 Smokey Bacon 的建议,你得到了你的列表类,你在“更快”的 C++ 中,但是调用那个 DLL 仍然有成本: 使用 P/Invoke 或 COM 互操作从运行时跳出会带来相当大的性能成本。
在跳之前,确保你从这次跳跃中“物有所值”。
基于 OP 更新的更新
如果您重复调用此循环,则需要绝对确保将整个循环逻辑封装在单个互操作调用中——否则编码的开销(如其他人所提到的)肯定会让您丧命。
我确实认为,鉴于问题的描述,问题不在于 C#/.NET 比 C“慢”,而更有可能是代码需要优化。正如此处提到的另一张海报,您可以在 C# 中使用指针来显着提高这种循环的性能,而无需编码。对于这种情况,在进入复杂的互操作世界之前,我会先研究一下。
关于c# - 模仿 C# 的 List<List<int>> 的 C 数据结构?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/343654/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!