function [Wii, wflag] = connect_module1(Wi)

%Wi = [1 1 0 0 2;1 0 2 4 0;1 0 2 4 0;1 1 0 0 2];


[w1,w2] = size(Wi);
Wi = Wi(2:end,:);
[w1,w2] = size(Wi);

Wii = zeros(w1,w2);

wflag = zeros(1,w2);
wmem = zeros(1,w2);

cur = 1;
while cur < w2
    flag = 0;
    for i = 1:w2
        if wmem(1,i) == 0
            con = 0;
            wmem(1,i) = 1;
            wflag(1,i) = cur;
            for j = 1:w2
                if Wi(i,j) > 0
                    wflag(1,j) = cur;
                    con = con + Wi(i,j);
                end
            end


    
            while true
                lag = 0;
                for j = 1:w2
                    if wflag(1,j) == cur && wmem(1,j) == 0
                        wmem(1,j) = 1; 
                        for k = 1:w2
                           if Wi(j,k) > 0 
                              wflag(1,k) = cur; 
                              con = con + Wi(j,k);
                              disp(con);
                           end
                        end
                        lag = 1;
                    end
                end

                if lag == 0
                    break;
                end
            end

    
            for j = 1:w2
                for k = 1:w2
                    if wflag(1,j) == cur && wflag(1,k) == cur
                        Wii(j,k) = con;
                    end
                end
            end
            flag = 1;
            cur = cur + 1;
        end

    end
    if flag == 0
        break;
    end
end

disp('ok');
    

