#Day2 C++

二维数组

矩阵转置
思考过程:

00 01 02 03 
10 11 12 13   j>i
20 21 22 23
30 31 32 33
i>j
//矩阵转置
#include <iostream>
using namespace std;
void trans(int a[][3],int line){
    for(int i=0;i<line;i++)
        for(int j=i+1;j<line;j++){
            int temp;
            temp=a[i][j];
            a[i][j]=a[j][i];
            a[j][i]=temp;
        }
}
int main()
{
    int a[3][3];
    for(int i=0;i<3;i++)
        for(int j=0;j<3;j++)
            cin>>a[i][j];
    for(int i=0;i<3;i++)
        for(int j=0;j<3;j++){
            cout<<a[i][j];  
            if(j==2)cout<<endl;
        }
        trans(a,3);
    for(int i=0;i<3;i++)
        for(int j=0;j<3;j++){
            cout<<a[i][j];  
            if(j==2)cout<<endl;
        }
        getchar();
        getchar();
        return 0;

}

二维数组的初始化

可采用下面两种格式:
int a[2][3]={1,2,3,}{1,2,3};

inta[2][3]={1,2,3,4,5,6};
上面的初始化按照数组的行来进行。有优先原则
初始化的值可以少于数组元素的个数。
若在定义二维数组时,给出了所有元素的初始化则行数可省略。

存储

按行存储,即先是第一行的元素,再是第二行…
有些语言是按列存储的

向函数传递二维数组

形参一般为不带数组行数的二维数组定义 + 行数
调用者需提供二维数组变量的名 + 行数
作为函数参数的二维数组的列数不能不写

addr(x[i][j])=x的内存首地址+i*列数+j//所以列数是必须的

矩阵乘法

int main()
{
    const int M=2,N=3,T=4;
    int a[M][N],b[N][T],c[M][T];
    //输入a,b
    //计算c
    for(int i=0;i<M;i++){
        for(int j=0;j<T;j++){
            c[i][j]=0;
        for(int m=0;m<N;m++)
            c[i][j]+=a[i][m]*b[m][j];
        }
    }
}

用数组实现求解约瑟夫问题(Josephus)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值