- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我想构建一个节省空间的模块化算术类。这个想法是模数 M 是一个不可变的属性,在实例化期间得到固定,所以如果我们有一个大数组(std::vector 或另一个容器)的值具有相同的 M,M 只需要存储一次。
如果 M 可以在编译时固定,这可以使用模板来完成:
template <typename num, num M> class Mod_template
{
private:
num V;
public:
Mod_template(num v=0)
{
if (M == 0)
V = v;
else
{
V = v % M;
if (V < 0)
V += M;
}
}
// ...
};
Mod_template<int, 5> m1(2); // 2 mod 5
不过,在我的应用中,我们应该可以表达M运行时。我所看到的是这样的:
template <typename num> class Mod
{
private:
const num M;
num V;
public:
Mod(num m, num v=0): M(abs(m))
{
if (M == 0)
V = v;
else
{
V = v % M;
if (V < 0)
V += M;
}
}
// ...
};
Mod<int> m2(5, 2); // 2 mod 5
Mod<int> m3(3); // 0 mod 3
这行得通,但是模 M 值的大 vector 使用了它所需空间的 2 倍。
我认为潜在的概念问题是不同模数的 Mod 在句法上属于同一类型,即使它们“应该”是不同的类型。例如,这样的语句
m2 = m3;
应该“自然”引发运行时错误(在我的版本中,它是“手动”引发的:检查内置于复制构造函数以及我实现的每个二元运算符中)。
那么,有没有办法实现某种动态类型,以便 Mod 对象的类型记住模数?如果能知道如何解决这个问题,我将不胜感激。
这对我来说是一个反复出现的问题,涉及各种数学结构(例如,在同一集合上存储许多排列,同一组的元素等)
编辑:据我所知,
模板是由类或文字参数化的类型。
我想要的:由 const 对象参数化的类型(const num
在这种情况下,const Group&
或 const Group *const
用于组等)。
这可能吗?
最佳答案
如果类(class)需要知道什么,在零存储空间中将很难做到M
应该没有任何外界帮助。可能您能做的最好的事情就是存储一个指向共享 M
的指针。 ,这可能会好一点,具体取决于 num
的大小。是。但它不如免费。
如果M
会更容易设计是所有需要它的函数的传入值。然后你可以做一些事情,比如创建一个共享相同 M
的对象池。 (有很多简单的方法可以设计这个;例如 map<num, vector<num> >
)并且只存储 M
一次去游泳池。调用者需要知道哪个池 Mod
对象来自,但这可能是它知道的事情。
很难单独完美地回答这个问题……了解更多关于调用代码的信息肯定会帮助您获得更好的答案。
关于C++类设计: dynamic typing alternative to template argument?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24371211/
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
我正在使用 gradle 1.4,并将 build.gradle 重命名为 buildExpr.gradle,将 settings.gradle 重命名为 settingExpr.gradle,这两个
使用 Ubuntu 16.04.7 我试图将 python3.8 作为我的默认 python 版本。我按照 here 给出的说明进行操作,但最终标准 python 版本没有改变。每当我运行 pytho
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 6年前关闭。 Improve this questi
我有一个函数,它对其参数进行模式匹配,以在 StateT () Maybe () 中生成计算。这个计算在运行时可能会失败,在这种情况下,我希望当前的模式匹配分支失败,可以这么说。 我非常怀疑是否可能有
我知道这类问题已经回答过几次,但我给出了问题的上下文以期待一些其他的架构替代方案。 考虑一个 CExpression 类: class CExpression { public:
当我的红色、绿色或蓝色变量发生变化时,我正在尝试使用 Combine 来更新颜色。我看过的示例使用 sink() ,这似乎适合我,但 eraseToAnySubscriber 是 MIA,我找不到替代
最近我不得不搜索一些字符串值来查看哪个匹配某个模式。在用户输入搜索词之前,字符串值的数量和模式本身都不清楚。问题是我注意到每次我的应用程序运行以下行时: if (stringValue.mat
我希望制作包含类对象列表的类对象的深拷贝,每个类对象都有自己的一组内容。对象不包含比整数和列表更令人兴奋的东西(没有字典,没有等待生成的生成器等)。我在一个循环中对 500-800 个对象执行深度复制
我正在尝试在表格中插入一个简单的行。有人可以指出这里发生了什么吗? CREATE TABLE recommendation_engine_poc.user_by_category (
使用 Get-ChildItem | Get-Member 我可以看到对象的方法和属性。但是我如何看到例如的不同可能值属性?我可以用 Get-ChildItem | Where-Object {$_.
我有一个任务是编写简单的解析器生成器,所以我编写了类似 ANTLR 的语法并尝试解析像“foo:bar;”这样的简单文件,但得到了以下输出: [@0,0:2='foo',,1:0] [@1,3:3='
这个问题已经有答案了: Why order matters in this RegEx with alternation? (3 个回答) Order of regular expression op
Ax 2009 中的 MorphX 报表设计器似乎不是“最好的”报表设计器。我不知道是不是我的错,或者 morphx 报表设计器是否有太多错误而无法完成他的工作。我猜是否有一些替代方案可以为 Ax 2
除了 OWASP XSS 过滤软件之外,还有其他方法可以防止 XSS 攻击吗?如果可以在 apache 级别进行阻止,我需要建议。我不是安全专家,因此需要详细信息。感谢您的帮助 最佳答案 当数据向最终
在我的 Java EE 7 程序中,我想使用 @Alternative 根据上下文、生产或测试来注入(inject)不同的实现。我所做的就是在 beans.xml 文件中声明用 @Alternativ
我有一个文本文件,其中包含遵循替代模式的行,例如: name: SomeName counterA: 0, counterB: 0, counterC: 0 name: SomeNameB count
我知道标准的单例模式是这样的: 原创 public class Singleton1 { public static Singleton1 _Instance; public stat
在 Haskell 中,您可以像这样为临时变量创建 where 条件: f x | cond1 x = a | cond2 x = g a | otherwise = f (h x
我认为我能找到的所有适用于 Android 的自定义按钮教程都假设您使用三种图像作为按钮:普通图像、按下图像和聚焦图像。 不是本质上将给定按钮资源的大小增加三倍(并为美工/UX 人员创造更多工作),是
我是一名优秀的程序员,十分优秀!