- 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/
我正在尝试使用 y 组合器在 Scala 中定义 gcd: object Main { def y[A,B]( f : (A => B) => A => B ) : A => B = f(y(f)
我正在尝试了解返回指向函数的指针的函数,在我尝试编译代码后,它给了我这种错误: cannot convert int (*(int))(int) to int (*(int))(int) in ass
所以我一直在关注 youtube 上的游戏编程教程,然后弹出了这段代码:bufferedImageObject.getRGB(int, int, int, int, int[], int, int);
我正在将时间现在 与存储在数据库某处的时间进行比较。数据库中存储的时间格式为“yyyyMMddHHmmss”。例如,数据库可能会为存储的时间值返回 201106203354。然后我使用一个函数将时间现
例如 Maze0.bmp (0,0) (319,239) 65 120 Maze0.bmp (0,0) (319,239) 65 120 (254,243,90) Maze0.bmp (0,0) (
评论 Steve Yegge的post关于 server-side Javascript开始讨论语言中类型系统的优点和这个 comment描述: ... examples from H-M style
我正在研究 C 的指针,从 Deitel 的书中我不明白 int(*function)(int,int) 和 int*function(int, int) 表示函数时。 最佳答案 C 中读取类型的经验
您好,我使用 weblogic 11g 创建 war 应用程序,我对 joda time 的方法有疑问 new DateTime(int, int, int, int, int, int); 这抛出了
Create a method called average that calculates the average of the numbers passed as parameters. The
var a11: Int = 0 var a12: Int = 0 var a21: Int = 0 var a22: Int = 0 var valueDeterminant = a11 * a12
我正在为一个项目设置 LED 阵列。我得到了一个 LED 阵列,可以根据引脚变化电压进行更改,但我无法添加更多引脚。 当我尝试时,编译失败并显示错误:函数“int getMode(int, int,
除了创建对列表执行简单操作的函数之外,我对 haskell 还是很陌生。我想创建一个列表,其中包含 Int 类型的内容, 和 Int -> Int -> Int 类型的函数. 这是我尝试过的: dat
这个问题已经有答案了: Java add buttons dynamically as an array [duplicate] (4 个回答) 已关闭 7 年前。 StackOverFlow问题今天
我有几个 EditText View ,我想在其中设置左侧的图像,而 setCompoundDrawablesWithIntrinsicBounds 似乎不起作用。图形似乎没有改变。 有人知道为什么会
#include using namespace std; int main() { static_assert(is_constructible, int(*)(int,int)>::val
fun sum(a: Int, b: Int) = a + b val x = 1.to(2) 我在找: sum.tupled(x),或者 sum(*x) 当然,以上都不能用 Kotlin 1.1.3
有一个函数: func (first: Int) -> Int -> Bool -> String { return ? } 返回值怎么写?我对上面 func 的返回类型感到很困惑。 最
type foo = A of int * int | B of (int * int) int * int 和 (int * int) 有什么区别?我看到的唯一区别在于模式匹配: let test_
我正在尝试制作一个 slider 游戏。在这个类中,我使用 Graphics 对象 g2 的 drawImage 方法来显示“拼图”的 block 。但在绘制类方法中,我收到此错误:找不到符号方法dr
我试着理解这个表达: static Func isOdd = i => (i & 1) == 1; 但是这是什么意思呢? 例如我有 i = 3。然后 (3 & 1) == 1 或 i = 4。然后
我是一名优秀的程序员,十分优秀!