Цитата(Цырилла @ 20.02.2007 20:57)

не использовать же тупой перебор чисел с суммированием?
Боюсь, что "тупого перебора" тут не избежать. Это оправдано в целом, так как изначальная последовательность не регламентирована. Можно, конечно, снчала пройтись по ней и выкинуть члены, которые сами по себе превосходят требуемую сумму - только потом все равно: вакамба! И то, это только в случае положительных Ai..
Единственная (но немалая) радость состоит в том, что перебор этот можно сделать рекуррентно

. Делаешь процедуру, входными параметрами которой является текущая сумма S и следующая позиция M в изначальной последовательности. В процедуре устраиваешь цикл по элементам от M до N. В этом цикле прибавляешь к S текущий (L-ый, M<=L<=N) элемент и смотришь: если сумма равнв K - выход из программы с триумфом, если нет - вызываешь эту же процедуру с параметрами S+AL и L+1. После этого просто вызываешь в главной программе эту процедуру с параметрами 0 и 1 - и дело в шляпе..
Если последовательность существенно положительная, также целесообразно устраивать проверку на переполнение (S>K), чтоб ускорить процесс..