第1个回答 2019-10-17
顺时针旋转,(xa, ya) 坐标变换: xb = ya; yb = (n-1)- xa;
#include <stdio.h>
#include <stdlib.h>
int main(int argc, char* argv[]) {
int i,j,xa,ya,xb,yb,n;
int *p,*q;
printf("输入n:");
scanf("%d", &n);
p = (int*) malloc(sizeof(int) * n*n);
q = (int*) malloc(sizeof(int) * n*n);
for (i=0;i<n;i++) {
for (j=0;j<n;j++) {
*(p+i*n+j) = i*n+j+1;
}
}
for (i=0;i<n;i++) {
for (j=0;j<n;j++) {
printf("%4d ", *(p+i*n+j));
}
printf("\n");
}
printf("\n");
//旋转90度
for (i=0;i<n*n;i++) {
xa= i/n; ya= i%n;
xb = ya; yb = n-1-xa;
*(q + xb*n+yb) = *(p+i);
}
printf("顺时针旋转90---------------------------------------------\n");
for (i=0;i<n;i++) {
for (j=0;j<n;j++) {
printf("%4d ", *(q+i*n+j));
}
printf("\n");
}
printf("\n");
free(p);
free(q);
return 0;
}本回答被提问者采纳
第2个回答 2019-10-17
#include <stdio.h>
int main()
{
int n, i, j;
scanf("%d", &n);
int ** matrix = (int**)malloc(sizeof(int)*n);
for (i = 0; i < n; i++)
{
matrix[i] = (int*)malloc(sizeof(int)*n);
}
for (i = 0; i < n; i++)
{
for (j = 0; j < n; j++)
{
scanf("%d", &matrix[i][j]);
}
}
for (j = 0; j < n; j++)
{
for (i = n - 1; i >= 0; i--)
{
printf("%4d", matrix[i][j]);
}
printf("\n");
}
return 0;
}
追问老哥输出不对- -
追答头文件加一个 #include
本回答被网友采纳
第3个回答 2020-09-12
#include<stdio.h>
int main()
{
int i,j,n,sum=1,temp;
int a[10][10];
scanf("%d",&n);
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
a[i][j]=sum;
sum=sum+1;
}
}
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
printf("%d ",a[3-j][i]);
}
printf("\n");
}
return 0;
}