C, C ++, C #, D, Java, 65 62 ไบต์
int d(int n){int s=0,i=1;for(;i<=n;++i)s+=n%i>0?0:i;return s;}
สิ่งนี้ใช้ได้กับภาษาการเขียนโปรแกรมทั้ง 5 ภาษาเพราะมีความคล้ายคลึงกัน
การเพิ่มประสิทธิภาพ C, C ++ และ D: 62 60 ไบต์
ใน C ++ และ D, จำนวนเต็มแปลงโดยปริยายเป็น booleans (Zero => false, ไม่ใช่ Zero => true) ดังนั้นคุณไม่จำเป็นต้องมี !=0
int d(int n){int s=0,i=1;for(;i<=n;++i)s+=n%i?0:i;return s;}
การปรับให้เหมาะสม D: ระบบเทมเพลต golfy, 55 ไบต์
T d(T)(T n){T s,i=1;for(;i<=n;++i)s+=n%i?0:i;return s;}
รหัสที่จะทดสอบ :
ค :
printf("%d %d %d %d %d", d(7), d(15), d(20), d(1), d(5));
C ++:
std::cout << d(7) << ' ' << d(15) << ' ' << d(20) << ' ' << d(1) << ' ' << d(5);
ค# :
class FindSum
{
int d(int n) { int s = 0, i = 1; for (; i <= n; ++i) s += n % i > 0 ? 0 : i; return s; }
static void Main(string[] args)
{
var f = new FindSum();
Console.WriteLine(string.Format("{0}, {1}, {2}, {3}, {4}", f.d(7), f.d(15), f.d(20), f.d(1), f.d(5)));
}
}
D:
writeln(d(7));
writeln(d(15));
writeln(d(20));
writeln(d(1));
writeln(d(5));
ชวา:
public class FindSum {
int d(int n){int s=0,i=1;for(;i<=n;++i)s+=n%i>0?0:i;return s;}
public static void main(String[] args) {
FindSum f = new FindSum();
System.out.println(String.format("%d, %d, %d, %d, %d", f.d(7), f.d(15), f.d(20), f.d(1), f.d(5)));
}
}