- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在尝试遍历双端队列直到排除最后一个条目。理想情况下,我会避免计算和比较长度,所以我尝试了
auto it_end = dq.rbegin(); it_end++;
for ( auto it = dq.begin(); it !=it_end; ) {
if ( cond() ) {
it = dq.erase( it );
} else {
it++;
}
}
但是编译器提示没有匹配操作数,这似乎可以理解,因为我有一个反向迭代器和一个常规迭代器。有没有一种优雅的方法可以在避免计数的最后一个元素之前停止?比如,抵消?我也试过 usign back,但结果是引用而不是迭代器,所以 != 也不高兴。
最佳答案
你可以只使用 dq.end() - 1
在结束前得到一个。
您还可以使用 std::remove
或 std::remove_if
来删除您想要的项目,而不是自己完成这项工作。请注意,这基本上有点像分区操作——它返回一个迭代器,您想要保留的所有内容都是从范围的开头到该迭代器。您要删除的所有内容都在该迭代器之后,直到您作为输入提供的范围的末尾。
在这种情况下,您可以按照以下一般顺序执行某些操作:
std::deque<int> vals { 1, 2, 3, 4, 5, 6, 7, 8};
// get an iterator one before the end of `vals`
auto end = vals.end()-1;
// remove the even items in the range (so all except `8`)
auto pos = std::remove_if(vals.begin(), end,
[](int v){ return v %2 == 0;}
);
// erase the items we just "removed"
vals.erase(pos, end);
// show the result
for (v : vals)
std::cout << v << ", ";
关于C++ deque迭代到倒数第二个元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43271285/
如果我有一个变量 8589934592 示例: var a = (8589934592 | 0); //a is 0 var b = (8589934591223 | 0); //b
随着我们提高音阶,音符频率增加; #define A4 440 // These are the frequencies of the notes in herts #define A
我有一个这样组织的列表: [('down', 0.0098000000000000309), ('up', 0.0015000000000000568), ('down', 0.00890000000
如果我有一个多项式 P,有没有办法计算 P^-1 模 Q,即 Q 是另一个多项式?我知道这两个多项式的系数都属于以 z 为模的整数域,即 z 是一个整数。 我不确定 SymPy 是否已经在其 galo
对于给定的文件,我可以向后计算行数吗?即从 EOF 开始,计算行数直到开始? 我可以 fseek 到文件末尾。从那里开始,继续寻找新行字符(新行的指示)并继续增加我的 line_number 计数。但
有什么方法可以编写带除法的 C 代码来命令编译器在代码中需要常规除法精度的几个特定位置不使用快速除法(通过倒数数学),即使在全局允许倒数数学的情况下也是如此? 理想情况下,有一种方法不是特定于编译器的
我正在尝试将照片从我计算机上的本地文件导入到我的 HTML 文件中。我已经设法做到了,但它是按升序排列的。我尝试添加一个变量 JavaScript $(document).ready( functio
我正在尝试使用 commons-math 计算 2 尾学生分布的逆。我正在使用 Excel 来比较值并验证结果是否正确。 所以使用excel计算TINV,自由度为5,我使用95.45% =TINV(0
我有一个 jQuery 相机插件,它使用以下命令来拍摄快照。 这是它运行的代码。 function take_snapshot() { // take snapshot and get i
我刚刚学会了训练 brain.js network 并且只是在玩它。然后我很好奇是否可以采取相反的方式 - 从输出预测输入? 这是我的代码 const brain = require('brain.j
如果精度不重要,有什么方法可以提高速度的倒数(X 的除法 1)? 所以,我需要计算 1/X。是否有一些解决方法让我失去精度但做得更快? 最佳答案 𝗛𝗲𝗿𝗲𝗛𝗲𝗿𝗲𝗛𝗼𝘄𝗧𝗼?
令 N 为整数。如果N = 2536,则反转N为6352。如果N = 1000000,则反转N为1。 给定一个整数 M,其中 1 <= M <= 10^(100000)。 我们需要找到一个整数 N 是
我是一名优秀的程序员,十分优秀!