Biorąc pod uwagę dwie liczby całkowite m i n który opisuje kolejność m*n matrycy wraz z[][] początkowo wypełniony z liczbami całkowitymi od 1 do m*n kolejno w A kolejność rzędu głównego . Jest też 2d szyk zapytanie[][] składający się z Q zapytania który zawiera trzy liczby całkowite, każda gdzie Pierwszy liczba całkowita T opisuje typ zapytania i Następny dwie liczby całkowite X I I opisz wiersz Lub kolumna to musi być operowany . Zadanie polega na proces te Q manipulowanie zapytaniami wraz z[][]. Każdy zapytanie jest jednym z trzech typów:
- [1xy]: zamień X t I I t rzędy maty[][].
- [2xy]: zamień X t I I t kolumny mat[][].
- [3xy]: wydrukuj element Na X t rząd i I t kolumna mat[][].
Przykłady:
Wejście: m = 3 n = 3
zapytanie[][] = [[1 0 1]
[3 0 0]
[3 1 0]
[2 0 1]
[3 0 0]
[3 1 0]]Wyjście: 4 1 5 2
ciąg javaWyjaśnienie: Początkowo macierz wygląda następująco:
z[][] = [[1 2 3]
[4 5 6]
[7 8 9]]
Pierwsza operacja [1 0 1] : Musimy zamienić wiersz 0 i wiersz 1.
Po tej operacji macierz staje się:
z[][] =[[4 5 6]
[1 2 3]
[7 8 9]]
W kolejnych dwóch operacjach musimy wypisać elementy z podanych komórek.
Czwarta operacja [2 0 1]: Musimy zamienić kolumnę 0 i kolumnę 1.
Po tej operacji macierz staje się:
z[][] =[[5 4 6]
[2 1 3]
[8 7 9]]
W kolejnych dwóch operacjach musimy wypisać elementy z podanych komórek.
Spis treści
- [Podejście naiwne] - O(q*n) czasu i O(m*n) przestrzeni
- [Podejście oczekiwane] - O(q) Czas i O(m + n) Przestrzeń
[Podejście naiwne] - O(q*n) czasu i O(m*n) przestrzeni
C++Pomysł jest taki tworzyć matryca wraz z[][] porządku m*n początkowo wypełniony z liczbami całkowitymi od 1 do m*n kolejno w A kolejność rzędu głównego . Na zapytania typ 1 I 2 tj. zamieniać trawers wymagany wiersz lub kolumnę i zamień każdy z jego elementów. A na zapytanie typ 3 tj. wydrukować po prostu drukujemy element pod określonym indeksem.
// C++ Program to perform queries in a matrix. #include using namespace std; // function to swap rows of the matrix. void swapRows(vector<vector<int>> &mat int r1 int r2) { for (int i = 0; i < mat[0].size(); i++) { swap(mat[r1][i] mat[r2][i]); } } // function to swap columns of the matrix. void swapCols(vector<vector<int>> &mat int c1 int c2) { for (int i = 0; i < mat.size(); i++) { swap(mat[i][c1] mat[i][c2]); } } // function to operate queries. void solveQueries(int m int n vector<vector<int>> &query) { // create a matrix or order m*n filled with // values from 1 to m*n. vector<vector<int>> mat(m vector<int>(n)); for (int i = 0; i < m; i++) { for (int j = 0; j < n; j++) { mat[i][j] = (i * n) + j + 1; } } // perform the queries on the matrix. for (int i = 0; i < query.size(); i++) { // if query is of type 1 // swap the rows. if (query[i][0] == 1) { swapRows(mat query[i][1] query[i][2]); } // if query is of type 2 // swap the columns. else if (query[i][0] == 2) { swapCols(mat query[i][1] query[i][2]); } // if query is of type 3 // print the value at the given index. else { cout << mat[query[i][1]][query[i][2]] << ' '; } } } int main() { int m = 3 n = 3; vector<vector<int>> query = {{1 0 1} {3 0 0} {3 1 0} {2 0 1} {3 0 0} {3 1 0}}; solveQueries(m n query); return 0; }
Java // Java Program to perform queries in a matrix. import java.util.*; class GfG { // function to swap rows of the matrix. static void swapRows(int[][] mat int r1 int r2) { for (int i = 0; i < mat[0].length; i++) { int temp = mat[r1][i]; mat[r1][i] = mat[r2][i]; mat[r2][i] = temp; } } // function to swap columns of the matrix. static void swapCols(int[][] mat int c1 int c2) { for (int i = 0; i < mat.length; i++) { int temp = mat[i][c1]; mat[i][c1] = mat[i][c2]; mat[i][c2] = temp; } } // function to operate queries. static void solveQueries(int m int n int[][] query) { // create a matrix or order m*n filled with // values from 1 to m*n. int[][] mat = new int[m][n]; for (int i = 0; i < m; i++) { for (int j = 0; j < n; j++) { mat[i][j] = (i * n) + j + 1; } } // perform the queries on the matrix. for (int i = 0; i < query.length; i++) { // if query is of type 1 // swap the rows. if (query[i][0] == 1) { swapRows(mat query[i][1] query[i][2]); } // if query is of type 2 // swap the columns. else if (query[i][0] == 2) { swapCols(mat query[i][1] query[i][2]); } // if query is of type 3 // print the value at the given index. else { System.out.print(mat[query[i][1]][query[i][2]] + ' '); } } } public static void main(String[] args) { int m = 3 n = 3; int[][] query = { {1 0 1} {3 0 0} {3 1 0} {2 0 1} {3 0 0} {3 1 0} }; solveQueries(m n query); } }
Python # Python Program to perform queries in a matrix. # function to swap rows of the matrix. def swapRows(mat r1 r2): mat[r1] mat[r2] = mat[r2] mat[r1] # function to swap columns of the matrix. def swapCols(mat c1 c2): for row in mat: row[c1] row[c2] = row[c2] row[c1] # function to operate queries. def solveQueries(m n query): # create a matrix of order m*n filled with # values from 1 to m*n. mat = [[(i * n) + j + 1 for j in range(n)] for i in range(m)] # perform the queries on the matrix. for q in query: # if query is of type 1 # swap the rows. if q[0] == 1: swapRows(mat q[1] q[2]) # if query is of type 2 # swap the columns. elif q[0] == 2: swapCols(mat q[1] q[2]) # if query is of type 3 # print the value at the given index. else: print(mat[q[1]][q[2]] end=' ') if __name__ == '__main__': m n = 3 3 query = [ [1 0 1] [3 0 0] [3 1 0] [2 0 1] [3 0 0] [3 1 0] ] solveQueries(m n query)
C# // C# Program to perform queries in a matrix. using System; class GfG { // function to swap rows of the matrix. static void SwapRows(int[] mat int r1 int r2) { for (int i = 0; i < mat.GetLength(1); i++) { int temp = mat[r1 i]; mat[r1 i] = mat[r2 i]; mat[r2 i] = temp; } } // function to swap columns of the matrix. static void SwapCols(int[] mat int c1 int c2) { for (int i = 0; i < mat.GetLength(0); i++) { int temp = mat[i c1]; mat[i c1] = mat[i c2]; mat[i c2] = temp; } } // function to operate queries. static void SolveQueries(int m int n int[][] query) { // create a matrix or order m*n filled with // values from 1 to m*n. int[] mat = new int[m n]; for (int i = 0; i < m; i++) { for (int j = 0; j < n; j++) { mat[i j] = (i * n) + j + 1; } } // perform the queries on the matrix. for (int i = 0; i < query.Length; i++) { // if query is of type 1 // swap the rows. if (query[i][0] == 1) { SwapRows(mat query[i][1] query[i][2]); } // if query is of type 2 // swap the columns. else if (query[i][0] == 2) { SwapCols(mat query[i][1] query[i][2]); } // if query is of type 3 // print the value at the given index. else { Console.Write(mat[query[i][1] query[i][2]] + ' '); } } } static void Main(string[] args) { int m = 3 n = 3; int[][] query = { new int[] { 1 0 1 } new int[] { 3 0 0 } new int[] { 3 1 0 } new int[] { 2 0 1 } new int[] { 3 0 0 } new int[] { 3 1 0 } }; SolveQueries(m n query); } }
JavaScript // JavaScript Program to perform queries in a matrix. // function to swap rows of the matrix. function swapRows(mat r1 r2) { [mat[r1] mat[r2]] = [mat[r2] mat[r1]]; } // function to swap columns of the matrix. function swapCols(mat c1 c2) { for (let i = 0; i < mat.length; i++) { [mat[i][c1] mat[i][c2]] = [mat[i][c2] mat[i][c1]]; } } // function to operate queries. function solveQueries(m n query) { // create a matrix or order m*n filled with // values from 1 to m*n. const mat = Array.from({ length: m } (_ i) => Array.from({ length: n } (_ j) => i * n + j + 1) ); // perform the queries on the matrix. for (const q of query) { // if query is of type 1 // swap the rows. if (q[0] === 1) { swapRows(mat q[1] q[2]); } // if query is of type 2 // swap the columns. else if (q[0] === 2) { swapCols(mat q[1] q[2]); } // if query is of type 3 // print the value at the given index. else { console.log(mat[q[1]][q[2]] + ' '); } } } // driver code const m = 3 n = 3; const query = [ [1 0 1] [3 0 0] [3 1 0] [2 0 1] [3 0 0] [3 1 0] ]; solveQueries(m n query);
Wyjście
4 1 5 2
Złożoność czasowa: O(q*n) wymagane do wykonania q zapytań typu 1 i 2.
Przestrzeń pomocnicza: O(m*n) przestrzeń pomocnicza wymagana do utworzenia macierzy wraz z[][] rzędu m*n.
[Podejście oczekiwane] - O(q) Czas i O(m + n) Przestrzeń
The element w dowolnej pozycji mata[x] [y] w macierzy można opisać jako mat[x][y] = (n*x) + y + 1 Gdzie N jest liczba kolumny . Zamiast bezpośrednio modyfikować macierz, możemy użyć dwa pomocniczy tablice wiersze [m] I kolumny [n] . The wydziwianie tablica jest zainicjowany z wartościami z Do m-1 reprezentujące indeksy wierszy i kol tablica jest zainicjowany z wartościami z Do n-1 reprezentujące indeksy kolumn.
Aby przetworzyć zapytanie dotyczące typ 1 która zamienia wydziwianie X I I my po prostu zamieniać the wartości z rzędy[x] I rzędy[y]. Podobnie w przypadku zapytania typ 2 która zamienia kolumny X I I My zamieniać the wartości z kolumny[x] I cols[y] . Na zapytanie typ 3 Który wydrukować the wartość na pozycji (x y) obliczamy pozycję za pomocą wzoru mat[x][y] = wiersze[x]*n + kolumny[y] + 1.
Poniżej implementacja powyższego pomysłu:
C++// C++ Program to perform queries in a matrix. #include using namespace std; // function to operate queries. void solveQueries(int m int n vector<vector<int>> &query) { // create two arrays rows and cols // and fill the value from 0 to size-1 vector<int> rows(m) cols(n); for(int i = 0; i < m; i++) { rows[i] = i; } for(int i = 0; i < n; i++) { cols[i] = i; } // perform the queries on the matrix. for (int i = 0; i < query.size(); i++) { // if query is of type 1 // swap the rows. if (query[i][0] == 1) { swap(rows[query[i][1]] rows[query[i][2]]); } // if query is of type 2 // swap the columns. else if (query[i][0] == 2) { swap(cols[query[i][1]] cols[query[i][2]]); } // if query is of type 3 // print the value at the given index. else { cout<< (rows[query[i][1]] * n) + cols[query[i][2]] + 1 << ' '; } } } int main() { int m = 3 n = 3; vector<vector<int>> query = {{1 0 1} {3 0 0} {3 1 0} {2 0 1} {3 0 0} {3 1 0}}; solveQueries(m n query); return 0; }
Java // Java Program to perform queries in a matrix. import java.util.*; class GfG { // function to operate queries. static void solveQueries(int m int n int[][] query) { // create two arrays rows and cols // and fill the value from 0 to size-1 int[] rows = new int[m]; int[] cols = new int[n]; for (int i = 0; i < m; i++) { rows[i] = i; } for (int i = 0; i < n; i++) { cols[i] = i; } // perform the queries on the matrix. for (int i = 0; i < query.length; i++) { // if query is of type 1 // swap the rows. if (query[i][0] == 1) { int temp = rows[query[i][1]]; rows[query[i][1]] = rows[query[i][2]]; rows[query[i][2]] = temp; } // if query is of type 2 // swap the columns. else if (query[i][0] == 2) { int temp = cols[query[i][1]]; cols[query[i][1]] = cols[query[i][2]]; cols[query[i][2]] = temp; } // if query is of type 3 // print the value at the given index. else { System.out.print((rows[query[i][1]]*n + cols[query[i][2]] + 1) + ' '); } } } public static void main(String[] args) { int m = 3 n = 3; int[][] query = { {1 0 1} {3 0 0} {3 1 0} {2 0 1} {3 0 0} {3 1 0} }; solveQueries(m n query); } }
Python # Python Program to perform queries in a matrix. # function to operate queries. def solveQueries(m n query): # create two arrays rows and cols # and fill the value from 0 to size-1 rows = [i for i in range(m)] cols = [i for i in range(n)] # perform the queries on the matrix. for q in query: # if query is of type 1 # swap the rows. if q[0] == 1: rows[q[1]] rows[q[2]] = rows[q[2]] rows[q[1]] # if query is of type 2 # swap the columns. elif q[0] == 2: cols[q[1]] cols[q[2]] = cols[q[2]] cols[q[1]] # if query is of type 3 # print the value at the given index. else: print((rows[q[1]] * n) + cols[q[2]] + 1 end=' ') if __name__ == '__main__': m n = 3 3 query = [ [1 0 1] [3 0 0] [3 1 0] [2 0 1] [3 0 0] [3 1 0] ] solveQueries(m n query)
C# // C# Program to perform queries in a matrix. using System; class GfG { // function to operate queries. static void SolveQueries(int m int n int[][] query) { // create two arrays rows and cols // and fill the value from 0 to size-1 int[] rows = new int[m]; int[] cols = new int[n]; for(int i = 0; i < m; i++) { rows[i] = i; } for(int i = 0; i < n; i++) { cols[i] = i; } // perform the queries on the matrix. for (int i = 0; i < query.Length; i++) { // if query is of type 1 // swap the rows. if (query[i][0] == 1) { int temp = rows[query[i][1]]; rows[query[i][1]] = rows[query[i][2]]; rows[query[i][2]] = temp; } // if query is of type 2 // swap the columns. else if (query[i][0] == 2) { int temp = cols[query[i][1]]; cols[query[i][1]] = cols[query[i][2]]; cols[query[i][2]] = temp; } // if query is of type 3 // print the value at the given index. else { Console.Write((rows[query[i][1]]*n + cols[query[i][2]] + 1) + ' '); } } } static void Main(string[] args) { int m = 3 n = 3; int[][] query = { new int[] { 1 0 1 } new int[] { 3 0 0 } new int[] { 3 1 0 } new int[] { 2 0 1 } new int[] { 3 0 0 } new int[] { 3 1 0 } }; SolveQueries(m n query); } }
JavaScript // JavaScript Program to perform queries in a matrix. // function to operate queries. function solveQueries(m n query) { // create two arrays rows and cols // and fill the value from 0 to size-1 let rows = new Array(m); let cols = new Array(n); for (let i = 0; i < m; i++) { rows[i] = i; } for (let i = 0; i < n; i++) { cols[i] = i; } // perform the queries on the matrix. for (const q of query) { // if query is of type 1 // swap the rows. if (q[0] === 1) { [rows[q[1]] rows[q[2]]] = [rows[q[2]] rows[q[1]]]; } // if query is of type 2 // swap the columns. else if (q[0] === 2) { [cols[q[1]] cols[q[2]]] = [cols[q[2]] cols[q[1]]]; } // if query is of type 3 // print the value at the given index. else { process.stdout.write(((rows[q[1]] * n) + cols[q[2]] + 1) + ' '); } } } const m = 3 n = 3; const query = [ [1 0 1] [3 0 0] [3 1 0] [2 0 1] [3 0 0] [3 1 0] ]; solveQueries(m n query);
Wyjście
4 1 5 2
Złożoność czasowa: O(q) q = liczba zapytań
Przestrzeń pomocnicza: O(m + n) przestrzeń pomocnicza wymagana do utworzenia dwóch tablic.