Cod sursa(job #3355554)

Utilizator vickgoodmanSava Victor vickgoodman Data 23 mai 2026 00:49:34
Problema Problema rucsacului Scor 0
Compilator java Status done
Runda Arhiva educationala Marime 0.95 kb
import java.io.*;

class Main {
    public static void main(String[] args) throws IOException {
        StreamTokenizer in = new StreamTokenizer(new BufferedReader(new FileReader("rucsac.in")));
        PrintWriter pw = new PrintWriter("rucsac.out");

        in.nextToken();
        int n = (int) in.nval;
        in.nextToken();
        int g = (int) in.nval;

        int[] dp = new int[g + 1];

        // Procesăm fiecare obiect pe rând
        for (int i = 0; i < n; i++) {
            in.nextToken();
            int w = (int) in.nval; // greutatea curentă
            in.nextToken();
            int p = (int) in.nval; // profitul curent

            // TRUCUL 1D: Parcurgem INVERS greutățile
            // Ne oprim direct la 'w', pentru că la j < w nu putem adăuga obiectul oricum
            for (int j = g; j >= w; j--) {
                dp[j] = Math.max(dp[j], dp[j - w] + p);
            }
        }

        pw.println(dp[g]);
        pw.close();
    }
}