Welcome to collectivesolver - Programming & Software Q&A with code examples. A website with trusted programming answers. All programs are tested and work.

Contact: aviboots(AT)netvision.net.il

Buy a domain name - Register cheap domain names from $0.99 - Namecheap

Scalable Hosting That Grows With You

Secure & Reliable Web Hosting, Free Domain, Free SSL, 1-Click WordPress Install, Expert 24/7 Support

Semrush - keyword research tool

Boost your online presence with premium web hosting and servers

Disclosure: My content contains affiliate links.

39,938 questions

51,875 answers

573 users

How to find all the possible rows which are permutations of a given row in a matrix with C

1 Answer

0 votes
#include <stdio.h>
#include <stdlib.h>

#define COLS 5

void printPermutationRows(int matrix[][COLS], int rows, int cols, int givenrow) {
    int *set = (int *)malloc(cols * sizeof(int));
    if (set == NULL) {
        perror("Memory allocation failed");
        exit(EXIT_FAILURE);
    }
    
    for (int j = 0; j < cols; j++) {
        set[j] = matrix[givenrow][j];
    }
    
    for (int i = 0; i < rows; i++) {
        if (i == givenrow) {
            continue;
        }
        
        int j;
        for (j = 0; j < cols; j++) {
            int k;
            for (k = 0; k < cols; k++) {
                if (matrix[i][j] == set[k]) {
                    break;
                }
            }
            if (k == cols) {
                break;
            }
        }
        
        if (j != cols) {
            continue;
        }
        
        printf("%d, ", i);
    }
    
    free(set);
}

int main()
{
    int givenrow = 1;
    
    int matrix[][COLS] = {
        {7, 9, 4, 3, 1},
        {4, 7, 9, 1, 3},
        {4, 7, 8, 1, 2},
        {1, 6, 9, 7, 4},
        {9, 1, 3, 7, 4},
    };
    
    int rows = sizeof matrix / sizeof matrix[0];
    int cols = sizeof matrix[0] / sizeof(int);
    
    printPermutationRows(matrix, rows, cols, givenrow);
    
    return 0;
}


/*
run:

0, 4,  
  
*/

 



answered Feb 20, 2024 by avibootz
...