OPTADS360
AANETWORK
AMBIENT
YOMEDIA
Banner-Video
IN_IMAGE

Viết chương trình xây dựng ma phương A?

  bởi hoàng duy 28/11/2021
ADSENSE/lession_isads=0
QUẢNG CÁO
 

Câu trả lời (1)

  • #include<stdio.h>

    #include<conio.h>

    #include<math.h>

    #include<vector>

    using namespace std;

    #define MAX 100

    void XayDungMaPhuongLe(vector<vector<int> > &matrix, int n);

    void XayDungMaPhuongChanKep(vector<vector<int> > &matrix, int n);

    void XayDungMaPhuongChanDonLe(vector<vector<int> > &matrix, int n);

    void XayDungMaPhuong(vector<vector<int> > &matrix, int n);

    void XuatMaTran(vector<vector<int> > &matrix, int n);

    void XuatMaTran(vector<vector<int> > &matrix, int n)

    {

    for(int i = 0; i < n; i++)

    {

    for(int j = 0; j < n; j++)

    {

    printf("%4d", matrix[i][j]);

    }

    printf("\n\n");

    }

    }

    void XayDungMaPhuongLe(vector<vector<int> > &matrix, int n)

    {

    int TongSoPhanTu = n * n;

    int i = 0, j = n / 2; // vị trí bắt đầu

    for(int k = 1; k <= TongSoPhanTu; k++)

    {

    matrix[i][j] = k;

    i--;

    j++;

    if(k % n == 0)

    {

    i += 2;

    --j;

    }

    else

    {

    if(j == n)

    {

    j -= n;

    }

    else if(i < 0)

    {

    i += n;

    }

    }

    }

    }

    /* Ma phương chẵn có 2 loại:

    - Ma phương kép: dạng 4n(n >= 1) VD: 4, 8, 12, 16

    - Ma phương đơn lẻ: dạng 4n + 2 (n >= 1) VD: 6, 10, 14, 18

    */

    void XayDungMaPhuongChanKep(vector<vector<int> > &matrix, int n)

    {

    vector<vector<int> > I(n, vector<int> (n, 0));

    vector<vector<int> > J(n, vector<int> (n, 0));

    int i, j;

    // Xây dựng I, J

    int index = 1;

    for(i = 0; i < n; i++)

    for(j = 0; j < n; j++)

    {

    I[i][j] = ((i + 1) % 4) / 2;

    J[j][i] = ((i + 1) % 4) / 2;

    matrix[i][j] = index;

    index++;

    }

    for(i = 0; i < n; i++)

    for(j = 0; j < n; j++)

    {

    if(I[i][j] == J[i][j])

    {

    matrix[i][j] = n * n + 1 - matrix[i][j];

    }

    }

    }

    void XayDungMaPhuongChanDonLe(vector<vector<int> > &matrix, int n)

    {

    int p = n / 2;

    vector<vector<int> > M(p, vector<int> (p, 0));

    XayDungMaPhuong(M, p);

    int i, j, k;

    for (i = 0; i < p; i++)

    for (j = 0; j < p; j++)

    {

    matrix[i][j] = M[i][j];

    matrix[i + p][j] = M[i][j] + 3 * p * p;

    matrix[i][j + p] = M[i][j] + 2 * p * p;

    matrix[i + p][j + p] = M[i][j] + p * p;

    }

    if (n == 2)

    return;

    vector<int> I(p, 0);

    vector<int> J;

    for (i = 0; i < p; i++)

    I[i] = i + 1;

    k = (n - 2) / 4;

    for (i = 1; i <= k; i++)

    J.push_back(i);

    for (i = n - k + 2; i <= n; i++)

    J.push_back(i);

    int temp;

    for (i = 1; i <= p; i++)

    for (j = 1; j <= J.size(); j++)

    {

    temp = matrix[i - 1][J[j - 1] - 1];

    matrix[i - 1][J[j - 1] - 1] = matrix[i + p - 1][J[j - 1] -1];

    matrix[i + p - 1][J[j - 1] - 1] = temp;

    }

    //j = 1, i

    //i = k + 1, k + 1 + p

    i = k;

    j = 0;

    temp = matrix[i][j]; matrix[i][j] = matrix[i + p][j]; matrix[i + p][j] = temp;

    j = i;

    temp = matrix[i + p][j]; matrix[i + p][j] = matrix[i][j]; matrix[i][j] = temp;

    }

    void XayDungMaPhuong(vector<vector<int> > &matrix,int n)

    {

    if (n % 2 == 1) //n Chẵn

    XayDungMaPhuongLe(matrix, n);

    else //n lẻ

    if (n % 4 == 0) // Chẵn kép

    XayDungMaPhuongChanKep(matrix, n);

    else // Chẵn đơn

    XayDungMaPhuongChanDonLe(matrix, n);

    }

    int main(int argc, char* argv[])

    {

    int n;

    printf("\nNhap n: ");

    scanf("%d", &n);

    vector<vector<int> > matrix(n, vector<int> (n, 0));

    if (n < 3)

    {

    printf("\nLoi!n phai lon hon 2 \n\n");

    return -1;

    }

    XayDungMaPhuong(matrix, n);

    XuatMaTran(matrix, n);

    getch();

    return 0;

    }

      bởi Lê Thánh Tông 29/11/2021
    Like (0) Báo cáo sai phạm

Nếu bạn hỏi, bạn chỉ thu về một câu trả lời.
Nhưng khi bạn suy nghĩ trả lời, bạn sẽ thu về gấp bội!

Lưu ý: Các trường hợp cố tình spam câu trả lời hoặc bị báo xấu trên 5 lần sẽ bị khóa tài khoản

Gửi câu trả lời Hủy
 
 

Các câu hỏi mới

NONE
OFF