草庐IT

pair_of_ints

全部标签

c# - 为什么 Array.Length 是一个 int,而不是一个 uint

这个问题在这里已经有了答案:Whydoes.NETuseintinsteadofuintincertainclasses?(7个答案)关闭9年前。为什么Array.Length是int,而不是uint。这让我很困扰(有点),因为长度值永远不会是负数。这也迫使我在自己的类中使用int作为长度属性,因为当你指定一个int值,这需要显式转换...所以最终的问题是:unsignedint(uint)有什么用吗?甚至微软似乎也不使用它们。

c++ - 使用 const 键类型引用调用 std::set of pointers 的 count 方法

我有一个类structS{boolfoo(constAType&v)const{returnvalues.count(&v);//compileerrorduetotheconstnessofv}private:std::setvalues;};这是一个简化版本。在实际代码中,foo做了一些复杂的事情。代码产生错误invalidconversionfrom‘constAType*’to‘std::set::key_type{akaAType*}’我认为foo应该采用'constAType&v'因为它不会改变v。成员变量“values”的类型不能为std::set,因为结构S的某些方法调

c++ - "Search words/strings in Matrix of Char"算法的复杂度

我的任务是从列表中搜索字母(20×20)单词(5)的网格。隐藏在网格中的任何单词总是以锯齿形段的形式出现,其长度可能只有2或3。锯齿形段只能从左到右或从下到上。所需的复杂度等于网格中字母数与列表中字母数的乘积。对于网格:••••••••••••••••••••••••••••ate•••••x••••••••••er•••••••e•••••••••it••••••••v•••••••ell••••••a••f••••••at••••e••••••rbg••••s•••••••ga•••••••和单词列表{"forward","iterate","phone","satellite"}

c++ - 分离轴定理: rotation around center of mass

问题出在Polygon::FindAxisLeastPenetration:doublePolygon::FindAxisLeastPenetration(unsignedint*faceIndex,constPolygon&polygonA,constPolygon&polygonB)const{doublebestDistance=-std::numeric_limits::infinity();unsignedintbestIndex;for(unsignedinti=0;iGetPosition());vertex.Subtract(polygonB.body->GetPosi

c++ - DFS : How to indicate the nodes of the connected components in C++

我正在做一个ACM竞赛的问题,以确定具有无向图G和属于每个组件的顶点的连通组件的数量。已经完成了DFS算法,计算无向图的连接组件的数量(问题的难点),但我想不出任何东西来指示属于每个组件的节点或有节点的记录。输入:第一行输入一个整数C,表示测试用例的个数。每个测试用例的第一行包含两个整数N和E,其中N表示图中的节点数,E表示图中的边数。然后是E行,每行有2个整数I和J,其中I和J表示节点I和节点J之间存在一条边(0≤I,J输出:在每个测试用例的第一行必须显示以下字符串“CaseG:Pcomponent(s)connected(s)”,其中G表示测试用例的数量(从1开始),P表示图中连接

c++ - boost::lexical_cast<std::string>(Int_Type) 可以抛出吗?

有没有可能boost::lexical_cast(Int_Type)扔?我唯一能想到的是字符串没有内存的地方,但是还有其他更合理的选择吗? 最佳答案 根据documentation,lexical_cast可以扔bad_lexical_cast.最重要的是,正如您已经提到的,可能存在动态分配,它总是会导致bad_alloc异常。编辑:至于具体情况lexical_cast,除了分配错误之外,链上的任何部分似乎都不太可能失败,但文档并不(据我所知)保证不会出现“错误转换”异常。 关于c++-

c++ - std::atomic 将一对原子 int32 视为一个原子 int64?

我有一对unsignedint32std::atomic_start;std::atomic_end;有时我想通过比较交换来设置开始或结束,所以我不希望在整个64位对上使用CAS可能导致虚假故障。我只想使用32位CAS。_end.compare_exchange_strong(old_end,new_end);现在我可以将开始和结束作为一个64位原子读取来获取。或者两个单独的32位读取。执行一次64位原子提取(编译器添加适当的内存栅栏)而不是使用两个内存栅栏进行两次单独的32原子位读取(或者编译器会优化它吗?)会不会更快?如果是这样,我将如何在C++11中做到这一点?

c++ - C++ 中将默认变量类型设置为 int 的任何选项

在c++代码中是否有任何选项省略变量类型或将变量类型设置为int以使用g++编译器编译Linux.constbufLen=2000;在solaris中编译顺利(因为我正在从solaris移植到linux)。还有一件事,我无法控制文件,因为它是由某些解析器生成的(由某些第三方以二进制形式提供)由于我无法更改c++文件(因为它每次在编译前生成),我需要一些选项(g++)以便我可以在编译期间包含以抑制/解决错误:error:ISOC++forbidsdeclarationof`bufLen`withnotype编辑:INFO:目前我正在使用的选项-c-fPIC-Wno-deprecated-

c++ - 在 C/C++ 中将非常大的 int(写为字符串)转换为二进制字符串

我有一个基数为10的数字,大约有10k位。我想将它转换成基数2(1010101001...)。我能想到的就是原始算法:取最后一位mod2->记下位数字除以2;在字符串上实现小学分部应该不难,但我认为它非常低效。如果我是对的,它将是O(l^2),其中l表示以10为基数的数字长度。可以更快地完成吗? 最佳答案 据我了解,您的大数字表示为十进制数字序列。如果是这样,您可以使用乘法和加法计算“二进制”表示:value=sum(iin0...n-1)10i*digiti此计算可以分而治之的方式拆分成多个部分,但我不确定您是否可以得出O(nlo

c++ - 如何将 std::unique_ptr<T> 与返回 int 的接口(interface)一起使用?

我想将open/closePOSIXAPI包装到一个RAII兼容对象中,例如std::unique_ptr。但是open函数返回一个int(即不是HANDLE,它是指向void的指针),并且我不确定如何将std::unique_ptr模板类与int一起使用。有人可以帮帮我吗? 最佳答案 真的,您想要的只是让close(intfileHandle)为您管理,对吗?为什么不创建一个带有为您调用close()的析构函数的简单C++类?我认为这就是您要寻找的行为。std::shared_ptr,friend只处理用new创建的堆指针,会调用