c语言旋转
❶ c语言二维数组通过指针旋转90度
//初始的二维数组:
//1234
//5678
//9101112
//13141516
//顺时针转90度后的二维数组:
//13951
//141062
//151173
//161284
#include<stdio.h>
//#include<stdlib.h>//该头文件暂时不用
//#include<string.h>//该头文件暂时不用
#defineN4
//原代码inta[N][N];//放在这里定义,二维数组a属于全局变量
//将二维数组通过指针旋转90度(顺时针转90度)
voidproc(intbuf[N][N],intn)
{
inti,j,t;
int*parr;//指向int类型的指针
parr=&buf[0][0];//将二维数组看成一维数组
for(i=0;i<=n-1;i++)
{
for(j=i;j<n-i-1;j++)
{
t=*(parr+i*n+j);
*(parr+i*n+j)=*(parr+(n-1-j)*n+i);
*(parr+(n-1-j)*n+i)=*(parr+(n-1-i)*n+n-1-j);
*(parr+(n-1-i)*n+n-1-j)=*(parr+j*n+n-1-i);
*(parr+j*n+n-1-i)=t;
}
}
}
voidOutput(inta[N][N])//输出二维数组
{
inti,j;
for(i=0;i<N;i++)
{
for(j=0;j<N;j++)
{
printf("%4d",a[i][j]);
}
printf(" ");
}
}
intmain()//原代码voidmain()
{
//N的数值不大,二维数组a可放在函数main里定义,作为局部变量
inta[N][N];
inti,j,c=0;
for(i=0;i<N;i++)
{
for(j=0;j<N;j++)
{
a[i][j]=++c;
}
}
Output(a);
printf(" ");
//原代码proc(&a[N][N],N);
proc(a,N);
Output(a);
return0;
}
❷ c语言怎么旋转一个矩阵
#include<stdio.h>
int main()
{int i,j,t,n,a[20][20];
scanf("%d",&n);
for(i=0;i<n;i++)
{for(j=0;j<n;j++)
{a[i][j]=i*n+j+1;
printf("%3d",a[i][j]);
}
printf(" ");
}
printf(" ");
for(i=0;i<=n/2;i++)
for(j=i;j<n-i-1;j++)
{t=a[i][j];
a[i][j]=a[j][n-1-i];
a[j][n-1-i]=a[n-1-i][n-1-j];
a[n-1-i][n-1-j]=a[n-1-j][i];
a[n-1-j][i]=t;
}
for(i=0;i<n;i++)
{for(j=0;j<n;j++)
printf("%3d",a[i][j]);
printf(" ");
}
return 0;
}
❸ C语言方阵旋转问题。
正确代码应该如下::::注意的是旋转90度哦。
#include<stdio.h>
#define N 4
int main()
{
int a[N][N]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16};
int i,j,(*p)[N];
int t[N][N];//用于交换
p=a;
for(i=0;i<N;i++)
{
for(j=0;j<N;j++)
printf("%d\t",p[i][j]);
printf("\n");
}
for(i=0;i<N;i++)
{
for(j=0;j<N;j++)
{t[j][N-i-1]=p[i][j];}
}
printf("\n顺时针旋转后的方阵为:\n");
for(i=0;i<N;i++)
{
for(j=0;j<N;j++)
printf("%d\t",t[i][j]);
printf("\n");
}
return 0;
}
附:你在用指针数组时注意在修改一个指针的值时修改了原来的值哦。有返回的,所以在下次使用时会出现不改修改的数据已经被修改了的哦
❹ 用c语言编程三角形绕一点旋转九十度怎么做
A(ax, ay) B(bx, by) C(cx, cy) 移动后A(ax0, ay0)...
1)ax = r*cosα ay = r*sinα
ax0 = r*cos(α+90) ay0=r*sin(α+90) 用三角函数展开就ok了
2)旋转90度就是坐标点从一个象限旋转到另一个象限,先判断正负,再将横纵坐标交换并根据正负情况乘以-1或者1 这个问题就是高中解析几何的旋转问题。或者图形学里的二维图形旋转问题
❺ C语言矩阵逆时针旋转
把最后的printf(" %d",a[i][j]);改成printf(" %d",b[i][j]); -----------------------------------------------------------#include<stdio.h>main(){int i,j,a[3][3]={{1,2,3},{4,5,6},{7,8,9}},b[3][3];for(i=0;i<=2;i++){for(j=0;j<=2;j++)printf(" %d",a[i][j]);printf("\n");}printf("\n");for(i=0;i<3;i++) {for(j=0;j<3;j++) </p><p>b[j][i]=a[i][2-j];<br> }for(i=0;i<=2;i++){for(j=0;j<=2;j++)</p><p>printf(" %d",b[i][j]);</p><p>printf("\n");</p><p>}getchar();}
❻ C语言如何编写旋转矩阵源代码
这里以顺时针旋转90°为例:
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#defineN4
voidmain()
{
inti,j;
inta[N*N],b[N][N];//这里设置旋转为4*4的矩形,自己在这里改成其它的矩形
int*p=a;//用指针来指向这个一维数组。这样在旋转赋值的时候会轻松很多
srand(time(NULL));
for(i=0;i<N*N;i++)
{
a[i]=rand()%100;//随机生成0~99
printf("%d ",a[i]);
if((i+1)%4==0)
printf(" ");
}
for(i=N-1;i>=0;i--) //旋转赋值,这里可修改旋转的方向和角度
for(j=0;j<N;j++,p++)
b[j][i]=*p;
printf("顺时针旋转90度后: ");
for(i=0;i<N;i++)
{for(j=0;j<N;j++)
printf("%d ",b[i][j]);
printf(" ");
}
}
这种旋转矩形的,个人建议生成一维数组,用指针指向改数组,再用指针来赋值;也可生成二维数组,再定义数组指针来指向,这样稍麻烦一些些。
❼ C语言中怎样将一个三行四列的二维数组 逆时针旋转90°啊,帮帮忙啊
下面程序的功能是将一个 3 行 4 列的数组进行逆时针旋转 90 度后输出,要求原始数组的数据随机输入,新数组以 4 行 3 列的方式输出。
主要涉及知识点:二维数组的输入及输出、循环嵌套与二维数组的结合、输出的格式控制。
代码实现:
#include<stdio.h>
intmain(){
inta[3][4],b[4][3],i,j;/*a存放原始数组数据,b存放旋转后数组数据*/
printf("input16numbers:");
/*输入一组数据存放到数组a中,然后旋转存放到b数组中*/
for(i=0;i<3;i++){
for(j=0;j<4;j++){
scanf("%d",&a[i][j]);
printf("%6d",a[i][j]);
b[3-j][i]=a[i][j];
}
printf(" ");
}
printf("arrayb: ");
for(i=0;i<4;i++){
for(j=0;j<3;j++)
printf("%6d",b[i][j]);
printf(" ");
}
return0;
}
❽ 怎样用C语言实现旋转
怎样用C语言实现旋转
#include <stdio.h>
void main()
{
int M;
int N;
int flag=0;
int num1=0;
int num2=1;
int i=0;
int j=0;
char str='A';
char Array[31][31];
printf("请输入矩阵的行M和矩阵的列N:");
scanf("%d%d",&M,&N);
Array[0][0]=str;
while(flag < M*N-1)
{
switch(num2%4)
{
case 1:
++j;
if(j == N-num1-1)
{
num2++;
}
break;
case 2:
++i;
if(i == M-num1-1)
{
num2++;
}
break;
case 3:
--j;
if(j == num1)
{
num2++;
}
break;
case 0:
--i;
if(i == num1+1)
{
num2++;
num1++;
}
break;
}
if(++str == 'Z'+1)
str='A';
Array[i][j]=str;
flag++;
}
for(i=0;i<M;i++)
{
for(j=0;j<N;j++)
{
printf("%c ",Array[i][j]);
}
printf("\n");
}
}