我有一个6位整数,比方说我要拆分成“153060”inta=15(前2位数字),intb=30(第二个2位数),intc=60(第三个2位数),首先想到的是将int转换为字符串,使用SubString(或变体)拆分它,然后再转换回int。不过,这似乎是一种非常低效的方法。谁能推荐一种更好/更快的方法来解决这个问题?谢谢!附加信息:拆分int的原因是因为6位整数表示HHMMSS,我想用它来创建一个新的DateTime实例:DateTimemyDateTime=newDateTime(年,月,日,a,b,c);但是,用户字段只能接受整数。 最佳答案
我有以下List集合,我需要找到集合中的最高整数。它可以有任意数量的整数,我可以多次使用相同的整数值。ListMyList=newList{3,4,6,7,9,3,4,5,5};用于查找最大整数的最简单算法是什么?我正在使用C#和.NET3.5框架。 最佳答案 你可以这样做:intmax=MyList.Max();参见Enumerable.Max了解详情。 关于c#-使用C#在通用列表中查找最大整数?,我们在StackOverflow上找到一个类似的问题: h
这个问题在这里已经有了答案:关闭12年前。PossibleDuplicate:HowdoIassignby“reference”toaclassfieldinc#?大家好-告诉我如何进行这项工作?基本上,我需要一个整数引用类型(int*可以在C++中使用)classBar{privaterefintm_ref;//Thisdoesn'texistpublicA(refintval){m_ref=val;}publicvoidAddOne(){m_ref++;}}classProgram{staticvoidmain(){intfoo=7;Barb=newBar(reffoo);b.Ad
我最初的问题是我需要在C#中实现一个非常快速的稀疏数组。最初的想法是使用正常的Dictionary并将其包装在我自己的类中以仅公开TValue类型参数。事实证明这很慢。所以我的下一个想法是将所需范围(UInt32.MinValue到UInt32.MaxValue)中的每个整数映射到某个大小的桶并使用它。所以我正在寻找一种将无符号整数X映射到桶Y的好方法,例如:将数字0-1023映射到8个不同的桶,每个桶包含128个数字,0-127、128-255。但如果有人有更好的方法在C#中实现快速稀疏数组,那也将不胜感激。 最佳答案 我也注意到
无缘无故,我决定寻找一种算法,该算法可以产生1...n之间的k个整数的所有可能选择,其中k个整数之间的顺序无关紧要(n选择k个东西)。出于完全相同的原因,这根本不是原因,我也用C#实现了它。我的问题是:您是否发现我的算法或代码有任何错误?而且,更重要的是,您能推荐一个更好的算法吗?请多关注算法而不是代码本身。这不是我写过的最漂亮的代码,但如果您看到错误,一定要告诉我。编辑:Alogirthm解释-我们持有k个指数。这会创建k个嵌套的for循环,其中循环i的索引是indices[i]。它模拟k个for循环,其中indices[i+1]属于嵌套在indices[i]循环中的循环。indic
我需要找到两个已排序整数数组的交集,而且速度非常快。现在,我正在使用以下代码:inti=0,j=0;while(i不幸的是,完成所有工作可能需要数小时。如何更快地完成?我找到了thisarticle使用SIMD指令的地方。是否可以在.NET中使用SIMD?你在想什么:http://docs.go-mono.com/index.aspx?link=N:Mono.Simd单片机http://netasm.codeplex.com/NetASM(注入(inject)asm代码到托管)还有类似http://www.atrevido.net/blog/PermaLink.aspx?guid=ac
在StackOverflow上有很多关于这个的问题。很多。但是我找不到这样的答案:使用C#适用于64位整数(相对于32位)快于:privatestaticintObvious(ulongv){intr=0;while((v>>=1)!=0){r++;}returnr;}甚至intr=(int)(Math.Log(v,2));我在这里假设64位IntelCPU。一个有用的引用是BitHackspage另一个是fxtbook.pdf然而,虽然这些提供了解决问题的有用方向,但它们并没有给出现成的答案。我正在寻找一个可重复使用的函数,它可以执行类似于_BitScanForward64的操作和_
我正在尝试确定C#ulong数字中的位数,我正在尝试使用一些数学逻辑而不是使用ToString().Length。我没有对这两种方法进行基准测试,但看过其他关于使用System.Math.Floor(System.Math.Log10(number))+1确定位数的帖子。似乎工作正常,直到我从999999999999997过渡到999999999999998,此时,我开始得到不正确的计数。有没有人遇到过这个问题?我在Whylog(1000)/log(10)isn'tthesameaslog10(1000)?看到过类似的强调Java的帖子还有一个帖子@Howtogettheseparat
非常简单的问题:inta=5;stringstr=a.ToString();既然ToString是System.Object的一个虚方法,是否意味着每次我为整数类型调用这个方法时,都会发生装箱? 最佳答案 你已经得到了答案告诉你什么时候ToString()被值类型覆盖,调用它时不会有装箱,但有一些实际看到它的方法很好。取类型int?(Nullable)。这是一个有用的类型,因为它是一个值类型,但是装箱可能会产生空引用,并且不能通过空引用调用实例方法。它确实有一个被覆盖的ToString()方法。它没有(也不可能有)重写的GetTyp
这个问题在这里已经有了答案:operatorsasstrings(13个答案)关闭9年前。如果这个问题已经得到回答,我很抱歉,但我没有找到合适的答案。我在C#中有一个字符串表达式,我需要将其转换为int或decimal值。例如:stringstrExp="10+20+30";输出应该是60。我该怎么做???