Я сделал быстрый тест на существующие ответы, которые
- используйте только стандартные инструменты (извините за такие вещи, как
lua
или rocket
),
- являются настоящими однострочниками,
- способны добавлять огромное количество чисел (100 миллионов), а
- быстрые (я проигнорировал те, которые заняли больше минуты).
Я всегда прибавлял числа от 1 до 100 миллионов, что выполнилось на моей машине менее чем за минуту для нескольких решений.
Вот результаты:
Python
:; seq 100000000 | python -c 'import sys; print sum(map(int, sys.stdin))'
5000000050000000
# 30s
:; seq 100000000 | python -c 'import sys; print sum(int(s) for s in sys.stdin)'
5000000050000000
# 38s
:; seq 100000000 | python3 -c 'import sys; print(sum(int(s) for s in sys.stdin))'
5000000050000000
# 27s
:; seq 100000000 | python3 -c 'import sys; print(sum(map(int, sys.stdin)))'
5000000050000000
# 22s
:; seq 100000000 | pypy -c 'import sys; print(sum(map(int, sys.stdin)))'
5000000050000000
# 11s
:; seq 100000000 | pypy -c 'import sys; print(sum(int(s) for s in sys.stdin))'
5000000050000000
# 11s
Awk
:; seq 100000000 | awk '{s+=$1} END {print s}'
5000000050000000
# 22s
Paste & Bc
Это исчерпало память на моей машине. Это работало для половины размера ввода (50 миллионов чисел):
:; seq 50000000 | paste -s -d+ - | bc
1250000025000000
# 17s
:; seq 50000001 100000000 | paste -s -d+ - | bc
3750000025000000
# 18s
Итак, я думаю, что на 100 миллионов чисел потребовалось бы ~ 35 с.
Perl
:; seq 100000000 | perl -lne '$x += $_; END { print $x; }'
5000000050000000
# 15s
:; seq 100000000 | perl -e 'map {$x += $_} <> and print $x'
5000000050000000
# 48s
рубин
:; seq 100000000 | ruby -e "puts ARGF.map(&:to_i).inject(&:+)"
5000000050000000
# 30s
C
Просто для сравнения я скомпилировал версию C и также протестировал ее, чтобы понять, насколько медленнее решения на основе инструментов.
#include <stdio.h>
int main(int argc, char** argv) {
long sum = 0;
long i = 0;
while(scanf("%ld", &i) == 1) {
sum = sum + i;
}
printf("%ld\n", sum);
return 0;
}
1043 *
:; seq 100000000 | ./a.out
5000000050000000
# 8s
Заключение
C, конечно, быстрее всего с 8 с, но решение Pypy только добавляет очень небольшие накладные расходы - около 30% к 11 с . Но, честно говоря, Pypy не совсем стандарт. У большинства людей установлен только CPython, который значительно медленнее (22 с), точно так же быстро, как и популярное решение Awk.
Самым быстрым решением на основе стандартных инструментов является Perl (15 с).