环形矩阵c语言
① c语言 环形排序
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
void Graph(char rect[9]);
int main()
{
int i,j,k;
char Cyc[9]={0};//Cyc[0]到Cyc[7]用于保存8个数,Cyc[8]为空白区
int CurNode=9,Temp;
srand((unsigned int)time(NULL));
for(i=0;i<8;i++)//随机产生序列
{
Cyc[i]=(rand()%8)+1;
if(CurNode==9 && Cyc[i]==1) CurNode=i;//记录数字1的位置
for(j=0;j<i;j++)
{
if(Cyc[i]==Cyc[j])
{
i--;
break;
}
}
}
printf("原始状态:\n");
Graph(Cyc);
printf("开始移动:\n");
for(i=2;i<=8;i++)//下一个要找的数
{
for(j=0;j<8;j++)//扫描找数
{
if(Cyc[j]==i)
{
Temp=(CurNode+1)%8;
if(i!=Cyc[Temp])//如果位置正确就不用再移
{
Cyc[8]=i;//移入中心区
Cyc[j]=0;
Graph(Cyc);
if(Temp!=j)
{
if(Temp>j) j+=8;
for(k=j;k>Temp;k--)
{
Cyc[k%8]=Cyc[(k-1)%8];//顺时针轮转
}
Cyc[Temp]=0;
Graph(Cyc);
}
Cyc[Temp]=Cyc[8];//从中心区移出
Cyc[8]=0;
Graph(Cyc);
}
CurNode=Temp;//记录当前位置
break;
}
}
}
printf("移动完成!\n");
return 1;
}
void Graph(char rect[9])
{
int i;
char buf[9];
for(i=0;i<9;i++)
{
if(rect[i]) buf[i]=rect[i]+48;
else buf[i]=' ';
}
printf("%c-%c-%c\n",buf[0],buf[1],buf[2]);
printf("|\\|/|\n");
printf("%c-%c-%c\n",buf[7],buf[8],buf[3]);
printf("|/|\\|\n");
printf("%c-%c-%c\n\n",buf[6],buf[5],buf[4]);
}
② c语言矩阵怎么写
方法1:直接定义10*10的数组,读取全部数据,再根据选择的行列数打印输出部分数据。
方法2:通过文件流指针的移动,跨过不需要的内容。(这里控制文件流指针可利用ftell和fseek函数来移动指定字节数)我是利用fscanf读取需要的内容,遇到需要跳行就用fgets来跳过。(注意常量参数根据自己需求修改)。
说明:边读取边打印输出,就不需要变量存储。我的代码是把读取出来的内容存放在三维数组中(文件内容你没指定,如是单纯数字,二维数组即可,我是作为字符串处理,故用三维数组。),数组是根据实际大小,动态申请,写成两个独立函数。
下面是代码:
#include <stdio.h>
#include <string.h>
#include <malloc.h>
#define MAXR 10//文件中矩阵最大行
#define MAXC 10//文件中矩阵最大列
#define MS 3//矩阵中元素字符串最大字符数(包含结束符号,不可小于实际内容)
#define MBUF 100//文件中一行最大字符数,可设置大一点
char ***getMem(int r,int c,int len);//动态申请一个三维数组
void freeMem(char ***datas,int r,int c);//释放数组空间
void showDatas(char ***datas,int r,int c);//打印输出结果
int main()
{
int r=MAXR+1,c=MAXC+1,i=0,j=0;
char ***datas=NULL,str[3],buf[MBUF];
FILE *fp=NULL;
printf("请输入要获取的行数和列数: ");
while(r<0 || r>MAXR || c<0 || c>MAXC)scanf("%d%d",&r,&c);
datas=getMem(r,c,MS);
fp=fopen("C:\test.data","r");
if(!fp) return 1;
while(fscanf(fp,"%s",str)!=-1)
{
if(i<c) strcpy(datas[j][i],str),i++;
if(i==c)
{
if(!fgets(buf,sizeof(buf),fp)) break;
i=0,j++;
}
if(j==r) break;
}
showDatas(datas,r,c);
freeMem(datas,r,c);
return 0;
}
void showDatas(char ***datas,int r,int c)
{
int i,j;
for(i=0;i<r;i++,printf(" "))
for(j=0;j<c;j++)
printf("%s ",datas[i][j]);
printf(" ");
}
void freeMem(char ***datas,int r,int c)
{
int i,j;
if(!datas)
{
for(i=0;i<r;i++,free(datas[i]))
for(j=0;j<c;j++)
free(datas[i][j]);
free(datas);
}
}
char ***getMem(int r,int c,int len)
{
int i,j;
char ***datas=NULL,**dr=NULL;
datas=(char ***)malloc(sizeof(char **)*r);
if(!datas) return NULL;
for(i=0;i<r;i++)
{
dr=(char **)malloc(sizeof(char *)*c);
if(!dr) return NULL;
else
{
for(j=0;j<c;j++)
{
dr[j]=(char *)malloc(sizeof(char)*len);
if(!dr[j]) return NULL;
}
datas[i]=dr;
}
}
return datas;
}
③ C语言中如何定义矩阵
两种方式可以参考:
1、最简单的就是二维数组,比如存储全是整形的一个m*n的矩阵。然后可以定义int a[m][n]。
输入或者输出可以用两层循环来完成,外层控制行m比如for(i=0;i<m;++i),内层控制列n比如for(j=0;j<n;++j);
2、第二种方式就是压缩矩阵进行存储,如果学了数据结构应该比较好理解。
结构体进行封装,比如:
第一步:先定义一个有效数据的位置
typedef struct node
{
int hang;int lie;int data;//用来存储一个有效数据位的行列和值
}node;
typedef struct matrix
{
node *m;//一个数组,用来存储所有的node数据
int sum;//记录一共有多少个有效数据位
}matrix;
④ c语言程序设计 回环矩阵
#include<stdio.h>
#include<stdlib.h>
#definesize10
intmain()
{inti=0,j=0,m=0,n=1,x,b,i1,j1;
inta[size][size]={0};
printf("inputanumber:
");
scanf("%d",&x);
b=x;
for(x;x>b/2;x--)
{for(j;j<x-1;j++)a[i][j]=n++;
for(i;i<x-1;i++)a[i][j]=n++;
for(j;j>m;j--)a[i][j]=n++;
for(i;i>m;i--)a[i][j]=n++;
m++;i++;j++;
}
if(b%2)a[b/2+1][b/2+1]=n;
for(i1=0;i1<b;i1++)
{for(j1=0;j1<b;j1++)printf("%5d",a[i1][j1]);
printf("
");
}
system("PAUSE");
return0;
}
⑤ 怎样用C语言写矩阵
用二维数组,如下:
#include <stdio.h>
main()
{
int i, j, a[4][4];
for ( i = 1; i < 4; i++ )
{
for ( j = 1; j < 4; j++ )
{
scanf ("%d", &a[i][j]);
}
}
//这样就可以将一个3*3 的矩阵存在2维数组中了
for ( i = 1; i < 4; i++ )
{
for ( j = 1; j < 4; j++ )
{
printf (" %-4d ", a[i][j]);
}
printf ("\n");
}
//这样就可以显示矩阵
return 0;
}
⑥ C语言 输出一个4*5循环矩阵
按照你的要求编写的C语言4*5的循环矩阵的程序如下
#include<stdio.h>
intmain(){
inta[]={1,2,3,4,5};
inti,j;
for(i=0;i<4;i++){
for(j=5-i;j<5;j++){
printf("%d",a[j]);
}
for(j=0;j<5-i;j++){
printf("%d",a[j]);
}
printf(" ");
}
return0;
}
如果需要存储在二维数组中,可以看看下面的C语言程序
#include<stdio.h>
intmain(){
inta[]={1,2,3,4,5},b[4][5];
inti,j,k;
for(i=0;i<4;i++){
k=0;
for(j=5-i;j<5;j++,k++){
b[i][k]=a[j];
}
for(j=0;j<5-i;j++,k++){
b[i][k]=a[j];
}
}
for(i=0;i<4;i++){
for(j=0;j<5;j++){
printf("%d",b[i][j]);
}
printf(" ");
}
return0;
}
运行结果
⑦ C语言中的矩阵是怎样计算的
矩阵的表示使用二维数组,当然二维数组通常情况下是不可以动态分配的,因此最好已开始定义一个足够大的数组来存放矩阵元素。至于加减乘逆等运算,主要是利用嵌套循环操作其单个元素,由于每个人的方法不一样就不详细说了。希望对你有所帮助。
⑧ 想输出一个1到10 的循环矩阵,用C语言编写程序如下:编译没有错误,但结果 有明显的错误,求解释,谢谢!
A[i][(i+j)%(N+1)]=a[j]; 你是从下标1开始填值,但是取模又使用了N+1(也就是说考虑了下标0),这是问题所在。
程序的灵魂在算法,以后先把算法搞清楚在动手编码,这样省去很多时间。对于你这个程序,它不是很好的算法,所以搞的自己非常头痛!
⑨ c语言 编一个3行4列的矩阵,用圆圈的
修改宏 ROW 和 COL 来修改你要的矩阵尺寸
修改宏 OUTPUT 来修改你要的输出的是圈或者其他字符
#include <stdio.h>
#define ROW (3)
#define COL (4)
#define OUTPUT ('o')
int main()
{
int i,j;
for(i = 0; i < ROW; i++)
{
for(j = 0; j < COL; j++)
{
printf("%c ", OUTPUT);
}
printf("\n");
}
return 0;
}
⑩ C语言如何输出ABCDCBA循环二维图形矩阵
代码:
#include <stdio.h>
int main()
{
char *s="ABCDCBABCDCBA";
int i;
for(i=0;i<7;i++)
printf("%.*s ",7,s+i);
return 0;
}
运行截图: