C# - 178个 169 157字符
假设允许像999这样的数字溢出到000,并且-+ ,. E不是数字的一部分。
class T{static void Main(){var a="".ToCharArray();for(int b=1,c,i=a.Length;i-->0;b=48>c|c>57?7:b>0?c>56?a[i]='0':++a[i]*0:b)c=a[i];System.Console.Write(a);}}
可读性更好的形式:
class T
{
static void Main()
{
var a="7teststring134this 123test string59 100".ToCharArray();
for (int b=3, c, i=a.Length; i-->0;
b=48>c|c>57
?7
:b>2
?c>56?a[i]='0':++a[i]*0
:b
) c=a[i];
System.Console.Write(a);
System.Console.ReadKey();
}
}
我是新来的,以前从未尝试过编码高尔夫球,只是尝试一下:)
我想知道是否有人有想法让它变得更短...
如果我们可以省略所有围绕实际代码的必要框架,那么参与C#将会很不错-这样,它只有82个字符,并且无需调用任何强大的系统功能即可。
与指针相同(182个字符):
class T
{
unsafe static void Main()
{
char[] a="7teststring134this 123test string59 100".ToCharArray();
int b=3;
fixed (char* s=&a[0])
for (var p=s+a.Length; p-->s; )
b=*p<48|*p>57
?7
:b>2
?*p>56?*p='0':++*p*0
:b;
System.Console.Write(a);
System.Console.ReadKey();
}
}
现在,不会溢出,这可以正确处理999种情况(223个字符):
class T
{
static void Main()
{
var s=new System.Text.StringBuilder("9999teststring134this 123test string99 100");
for (int b=3, c, i=s.Length; i-->0; )
{
c=s[i];
b=48>c|c>57
?b>8?8:7
:b>2
?c>56?c-(s[i]='0'):++s[i]*0
:b;
if (b>8&i<1|b==8) s.Insert(i+9-b, '1');
}
System.Console.Write(s);
System.Console.ReadKey();
}
}
另一个不同的旧版本,它从标准输入中读取并使用递归:
namespace System {
using C=Console;
class T {
class t {
byte b=1;
string s="";
void R() {
var c=C.Read();
if (c>31) {
R();
if (48>c|c>57) b=1;
else if (b==1) c=c==57?48:++c*b--;
s=(char)c+s;
}
}
public t() {
R();
C.Write(s);
}
}
static void Main() {
new t();
C.ReadKey();
}
}
}
注意:Console.ReadKey();
字符串本身不应该计算在内。
我已经对此进行了多次改进,请参见评论。我会说:仍然有更多改进的余地:)抱歉,不过,但是我认为不同版本足够有趣,可以保留它们。