YOMEDIA
NONE

Viết chương trình dịch phải xoay vòng theo chiều kim đồng hồ các giá trị nằm trên biên ma trận?

Theo dõi Vi phạm
ATNETWORK

Trả lời (1)

  • #include<stdio.h>

    #include<conio.h>

    #include<math.h>

    #define MAX 100

    void NhapMang(int a[][MAX], int &dong, int &cot)

    {

    //Nhập số dòng

    do

    {

    printf("\nNhap vao so dong: ");

    // Cách tà đạo: scanf("dong =%d",&dong); // Lúc nhập phải viết thêm chữ ( dong = ) ở khung console

    scanf("%d",&dong);

    if(dong < 1 || dong > MAX)

    {

    printf("\nSo dong khong hop le. Xin kiem tra lai!");

    }

    }while(dong < 1 || dong > MAX);

    //Nhập số cột

    do

    {

    printf("\nNhap vao so cot: ");

    scanf("%d",&cot);

    if(cot < 1 || cot > MAX)

    {

    printf("\nSo cot khong hop le. Xin kiem tra lai!");

    }

    }while(cot < 1 || cot > MAX);

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

    {

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

    {

    printf("\nNhap a[%d][%d] = ", i, j);

    scanf("%d", &a[i][j]);

    }

    }

    }

    void XuatMang(int a[][MAX], int dong, int cot)

    {

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

    {

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

    {

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

    }

    printf("\n\n");

    }

    }

    void DichPhaiXoayVongTheoChieuKimDongHoCacGiaTriNamTrenBien(int a[][MAX], int dong, int cot)

    {

    int i, j;

    int temp = a[0][0]; // lấy đi 1 ô tạo chỗ trống để dịch chuyển

    // dịch chuyển cột bên trái lên trên

    for(i = 0, j = i; i < dong - 1; i++) // giả sử dòng = 4, cột = 5

    {

    a[i][j] = a[i + 1][j]; // chạy từ i = 0 đến i = 3 thì dừng, j = 0

    }

    // dịch chuyển hàng dưới từ phải qua trái

    for (j, i; j < cot - 1; j++)

    {

    a[i][j] = a[i][j + 1]; // i = 3, j chạy từ 0 đến 4 thì dừng

    }

    // dịch chuyển cột bên phải từ trên xuống

    for (i, j; i > 0; i--)

    {

    a[i][j] = a[i - 1][j]; // i chạy từ 3 về 0 thì dừng, j = 4

    }

    // dịch chuyển hàng trên từ trái qua phải

    for (i, j; j > 1; j--)

    {

    a[i][j] = a[i][j - 1]; // i = 0, j chạy từ 4 về 1 thì dừng

    }

    // dịch chuyển xong bỏ ô kia về để lấp đầy ma trận

    a[0][1] = temp;

    }

    int main()

    {

    int a[MAX][MAX], dong, cot;

    int cot1, cot2;

    NhapMang(a, dong, cot);

    XuatMang(a, dong, cot);

    DichPhaiXoayVongTheoChieuKimDongHoCacGiaTriNamTrenBien(a, dong, cot);

    printf("\nMa tran sau khi bien doi\n");

    XuatMang(a, dong, cot);

    getch();

    return 0;

    }

      bởi Nguyễn Vũ Khúc 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
 
NONE

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

AANETWORK
 

 

YOMEDIA
ATNETWORK
ON