using System; using System.Linq; using System.Collections.Generic; namespace Algorithm { class Program { static void Main(string[] args) { // 写経 var l = Console.ReadLine().Split().Select(int.Parse).ToArray(); int N = l[0], M = l[1], K = l[2]; var A = new int[N][]; for (var i = 0; i < N; i++) A[i] = Console.ReadLine().Split().Select(int.Parse).ToArray(); var dp = new int[K + 1]; dp[0] = 1; for (var i = 0; i < N; i++) { var tmp = new int[K + 1]; for (var j = 0; j < M; j++) { for (var k = 0; k + A[i][j] <= K; k++) { if (dp[k] > 0) tmp[k + A[i][j]] = 1; } } dp = tmp; } for (var i = K; i >= 0; i--) { if (dp[i] > 0) { Console.WriteLine(K - i); return; } } Console.WriteLine(-1); } } }