Ⅰ 用c语言设计一个函数,使其可以输出4*4的矩阵。设计完这个函数以后在main函数里怎么调用,该怎么写啊
int f(int a[]){
int i;
int j;
for(i=0;i<4;i++){
for(j=0;j<4;j++){
printf("%d ",a[i*4+j]);
}
printf("\n");
}
}
int shuzhu[16];
int main(){
int i,j;
for(i=0;i<4;i++) for(j=0;j<4;j++) scanf("%d",&shuzhu[i*4+j]);
f(shuzhu);
return 0;
}
Ⅱ 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++中面向对象的程序设计方法实现矩阵的常用算法
#include<iostream>
usingnamespacestd;
classMatrix{
private:
introw;
intcol;
int**p;
public:
//矩阵的行列
Matrix(int*pm,intr,intc){
row=r;
col=c;
//创建二维数组
p=newint*[row];
for(inti=0;i!=row;++i){
p[i]=newint[col];
}
//矩阵元素赋值
if(pm!=NULL)
for(inti=0;i!=row;i++){
for(intj=0;j!=col;++j){
p[i][j]=pm[i*col+j];
}
}
}
//矩阵加法,结果存放在调用该函数的矩阵
voidadd_mm(Matrix&M){
for(inti=0;i<row;++i){
for(intj=0;j<col;++j){
this->p[i][j]+=M.p[i][j];
}
}
}
//矩阵减法,结果存放在调用该函数的矩阵
voidsub_mm(Matrix&M){
for(inti=0;i<row;++i){
for(intj=0;j<col;++j){
this->p[i][j]-=M.p[i][j];
}
}
}
//数与矩阵的乘法,结果存放在调用该函数的矩阵
voidmulti_num(intnum){
for(inti=0;i<row;++i){
for(intj=0;j<col;++j){
p[i][j]*=num;
}
}
}
//矩阵与矩阵的乘法,结果存放在新产生的矩阵中
Matrixmulti_mm(Matrix&M){
if(col!=M.row)//若不满足矩阵相乘的条件,返回一个0行0列的矩阵。
returnMatrix(NULL,0,0);
MatrixnewM(NULL,row,M.col);
//初始化新矩阵
for(size_ti=0;i!=newM.row;++i){
for(size_tj=0;j!=newM.col;++j){
newM.p[i][j]=0;
}
}
for(inti=0;i!=row;++i){
for(intj=0;j!=M.col;++j){
for(intk=0;k!=col;++k){
newM.p[i][j]+=this->p[i][k]*M.p[k][j];
}
}
}
returnnewM;
}
//矩阵的转置,返回一个新的转置矩阵
Matrixtranspose(){
MatrixnewM(NULL,col,row);
for(inti=0;i<row;++i){
for(intj=0;j<col;++j){
newM.p[j][i]=p[i][j];
}
}
returnnewM;
}
voidmyDisplay(){
for(inti=0;i!=row;++i){
for(intj=0;j!=col;++j){
cout<<p[i][j]<<"";
}
cout<<endl;
}
}
};
intmain(){
intarr1[][3]={
{1,1,1},
{2,2,2}
};
intarr2[][3]={
{10,10,10},
{20,20,20}
};
cout<<"矩阵1:"<<endl;
Matrixm1(&arr1[0][0],2,3);
m1.myDisplay();
cout<<"矩阵2:"<<endl;
Matrixm2(&arr2[0][0],2,3);
m2.myDisplay();
cout<<"矩阵1加矩阵2:"<<endl;
m1.add_mm(m2);
m1.myDisplay();
cout<<"矩阵1减矩阵2:"<<endl;
m1.sub_mm(m2);
m1.myDisplay();
intnum=100;
cout<<"矩阵1与数"<<num<<"的乘法:"<<endl;
m1.multi_num(num);
m1.myDisplay();
intarr3[][2]={
{10,10},
{20,20},
{30,30}
};
Matrixm3(&arr3[0][0],3,2);
cout<<"矩阵3:"<<endl;
m3.myDisplay();
cout<<"矩阵1与矩阵3的乘法:"<<endl;
m1.multi_mm(m3).myDisplay();
cout<<"xxxxx"<<endl;//
cout<<"矩阵1的转置:"<<endl;
m1.transpose().myDisplay();
system("pause");//按任意键继续
return0;
}
执行结果:
Ⅳ C语言设计一个函数,使其任意输入一个二维数组都可以输出一个4*4的矩阵; 然后函数调用,这个怎么编
#include "stdio.h"
void d(int a[4][4])
{
for(int y=0;y<4;y++)
{
for(int x=0;x<4;x++)
{
printf("%d ",a[y][x]);
}
printf("\n");
}
}
void main()
{
int a[4][4]={1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4};
d(a); //调用
}
Ⅳ 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语言完成课程设计:矩阵的基本运算,如何完成
匿名2010-04-27 矩阵是线性代数和矩阵论研究的主要对象,失求解微分方程组的重要工具,也是计算机图形学和计算机游戏开发的重要数学基础。矩阵的主要运算有数乘矩阵、两矩阵相加、相减、相乘和相除以及矩阵的转置,由于矩阵的除法涉及奇异值分解的问题,比较复杂,本课程设计暂不要求,紧要求完成矩阵最大维数不大于五维的矩阵数乘、加法、减法、乘法以及转置运算。 数学模型或问题分析: MA={ a00 a01 a02 ….. a0n a10 a11 a12 …... a1n . . . . . . . . am0 am1 am2 …… amn }= [ aij]i=1,2,3...m,j=1,2,3....n. MB= { b00 b01 b02 ….. b0q b10 b11 b12 …... b1q . . . . . . . . bp0 bp1 bp2 …… apq }=[brc]r=0,1,2...p,c=0,1,2...n。 利用实数k 相乘 。 我来回答匿名
Ⅶ 如何用C语言定义矩阵
矩阵其实就是二维数组,在进行编码的时候,矩阵就会被定义成为二维数组
Ⅷ c语言矩阵,不用库函数怎么做
提示你一下,二维数组