矩阵转置用指针作为函数参数,为什么输出结果这么奇怪?

#include
#include
#define N 3
#define M 3
/*238-4.编写一个函数(参数用指针)将一个3×3矩阵转置。*/
void matrixtranspose(int (*p)[M],int(*p1)[M])
{
int i,j;
for(i=0;i<N;i++)
{
for(j=0;j<M;j++)
{
((p1+j)+i)=*(*(p+i)+j);
}
}
}
void display(int (*p)[M])
{
int i,j;
for(i=0;i<N;i++)
{
for(j=0;j<M;j++)
{
printf("%2d",*(*(p+i)+j));
}
printf("\n");
}
}
int main()
{
int i,j,(*p)[M],a[N][M]={0},(*p1)[M];
for(i=0;i<N;i++)
{
for(j=0;j<M;j++)
{
scanf("%d ",&a[i][j]);
}
}
p=a;
display(p);
p1=a;
matrixtranspose(p,p1);
display(p1);
return 0;
}
图片说明


2个回答

//p1和p指向同一个指针a 所以转置交换数据时出错 重新定义b数组 p1指向b即可
int main()
{
int i, j, (*p)[M], a[N][M] = { 0 }, b[N][M] = { 0 },(*p1)[M];
for (i = 0; i<N; i++)
{
for (j = 0; j<M; j++)
{
scanf_s("%d ", &a[i][j]);
}
}
p = a;
display(p);
p1 = b;
matrixtranspose(p, p1);
display(p1);
return 0;
}

因为你的p和p1所指的内存空间都是二维数组a,所以当你执行转置函数,当你把p1所指的内容修改了,那么p所指的内容也被修改了,也就是说,p和p1指的是同一块内存空间

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
编写函数zhuanz(int (*p)[4]) 用行指针作参数实现矩阵转置

/*在主函数中定义整型数组a[4][4],从键盘输入值赋给数组元素后,调用zhuanz函数将a数组转置,并输出转置后的数组。*/ #include<stdio.h> #include<stdlib.h> main() {/************found************/ } zhuanz(int (*p)[4]) {/************found************/ }/*萌新崩溃,还有就是*(p)[4]和*p[4]什么区别,,*/

C语言:运用指针,输出3*3矩阵的转置阵。大佬们帮忙看看哪里出问题了

``` #include "stdafx.h" #include <stdio.h> int _tmain(int argc, _TCHAR* argv[]) { void fun(int *x); int a[3][3],i; int *p=&a[0][0]; printf("请输入一个整形矩阵:"); for(i=0;i<3;i++) { scanf("%d %d %d",&a[i][0],&a[i][1],&a[i][2]); } fun(p); printf("输出转置矩阵:\n"); for(i=0;i<3;i++) { printf("%d %d %d\n",a[i][0],a[i][1],a[i][2]); } return 0; } void fun(int *x) { int m,n,s; for(m=0;m<3;m++) { for(n=0;n<3;n++) { s=*(x+3*m+n); *(x+3*m+n)=*(x+3*n+m); *(x+3*n+m)=s; } } } ``` 输入:1 2 3 4 5 6 7 8 9 输出:1 2 3 4 5 6 7 8 9 结果依然是原矩阵,是哪一步出问题了呢?

指针变量作为函数参数

想知道swap函数中*p1与*p2交换了,但主函数中a与b为什么交换了,只知道*p1和*p2交换后p1和p2指向地址中的对象交换了,但为什么a与b还能交换啊![图片](https://img-ask.csdn.net/upload/201711/18/1510965723_257218.jpg)

请各位查看一下c 语言用指针转置为什么失败

我现在在做矩阵转置作业,可是我的转置方法无法成功,请问哪里有问题。 在转置transposeMar题型那里 ``` #include <stdio.h> #include<string.h> #include<stdlib.h> #include<time.h> #define ROWS 5 #define COLS 5 // int random_number = rand() % range + min void fillMatrix(int matrix[ROWS][COLS]) { srand(time(NULL)); for(int i =0;i<ROWS;i++) { for(int j=0;j<COLS;j++) { matrix[i][j]= rand()%100; } } } void printMatrix(int matrix[ROWS][COLS]) { for(int i =0;i<ROWS;i++) { for(int j=0;j<COLS;j++) { printf("%d ",matrix[i][j]); } printf("\n"); } } **void transposeMatrix (int matrix[ROWS][COLS]) { int tmp, i ,j; int *p; p=&matrix[0]; for (i = 0; i < ROWS; i++) { for (j = 0 ; j < COLS; j++) { tmp = *(p + 5* i + j); *(p + 5 * i + j) = *(p + 5 * j + i); *(p + 5* j + i) = tmp; } } }** void multiplyMatrix(int m1[2][COLS],int m2[ROWS][COLS],int result[ROWS][COLS]) { for(int i =0;i<ROWS;i++) { for(int j=0;j<COLS;j++) { int result_d=0; for(int k=0;k<COLS;k++) { result_d=result_d+m1[i][k]*m2[k][j]; } result[i][j]=result_d; } } } int main() { int matrix[ROWS][COLS]; fillMatrix(matrix); printMatrix(matrix); transposeMatrix(matrix); printMatrix(matrix); int matrix2[2][COLS]={0,1,2,3,4,5,6,7,8,9}; int result[ROWS][COLS]; multiplyMatrix(matrix2, matrix, result); printMatrix(result); return 0; } ```

【C语言】有关数组转置与指针应用的题目,求大佬解答

编写函数实现矩阵(4行4列)的转置。要求函数的实参为数组名,形参为指针形式。

一个矩阵转置的问题,错在哪里?

#define M 4 #include <stdio.h> int main() { int a[M][M]={{1,2,3,4},{5,6,7,8},{9,10,11,12},{13,14,15,16}}; int i,j; for(i=0;i<M;i++) { for(j=0;j<M;j++) printf("%d\t", a[i][j]); printf("\n"); } for(i=0;i<M;i++) { for(j=0;j<M;j++) { int t=a[i][j]; a[i][j]=a[j][i]; a[j][i]=t; } } for(i=0;i<M;i++) { for(j=0;j<M;j++) printf("%d\t", a[i][j]); printf("\n"); } return 0; }

c语言简单题,求矩阵的转置矩阵

![图片说明](https://img-ask.csdn.net/upload/201901/04/1546611499_210346.png) 我的答案: ``` #include <stdio.h> #define N 10 void Transpose(int (*a)[N], int n); void Swap(int *x, int *y); void InputMatrix(int (*a)[N], int n); void PrintMatrix(int (*a)[N], int n); void InputMatrix(int (*a)[N], int n) { int i,j; for(i = 0;i < n ;i++) { for(j = 0;j < n; j++) { scanf("%d",&a[i*n + j]); } } } void Transpose(int (*a)[N], int n) { int i,j; for(i = 0;i < n ;i++) { for(j = 0;j < n; j++) { Swap(&a[i*n + j], &a[j*n + i]); } } } void Swap(int *x, int *y) { int temp; temp = *x; *x = *y; *y = temp; } PrintMatrix(int (*a)[N], int n) { int i,j; for(i = 0;i < n ;i++) { for(j = 0;j < n ; j++) { printf("%d\t", *a[i*n + j]); } printf("\n"); } } int main() { int n,s[N][N]; printf("Input n:"); scanf("%d",&n); printf("Input %d*%d matrix:\n",n,n); InputMatrix( s, n); Transpose( s, n); printf("The transposed matrix is:\n"); PrintMatrix( s, n); return 0; } ``` 请问哪里错了?该怎么改?

二维数组列数由用户输入,该怎样在定义函数时传入二维数组作为函数参数?

![图片说明](https://img-ask.csdn.net/upload/202004/08/1586314740_244236.png) 编写一个矩阵转置函数,矩阵的行数和列数在程序中由用户输入 ``` #include <iostream> using namespace std; /* run this program using the console pauser or add your own getch, system("pause") or input loop */ void matrixTranspose(int (*a)[cols],int rows,int cols) //矩阵转置函数 /*二维数组作为函数参数必须将列数写入形式参数中, 二维数组的作为函数参数的传入方法: 1.int sum_arr(int a[N][N],int size)size的值是行数,二维数组可以看作是 元素为数组的一维数组 example:C++.P207 2.int sum_arr(int (*a)[cols],int size) 两种方法函数中调用都要用a[i][j] 数组的长度也要作为参数传入,不在函数的内部定义大小*/ { int b[N][N]={0}; int i=0,j=0; for(i=0;i<N;i++) { for(j=0;j<N;j++) { b[j][i]=a[i][j]; } } for(i=0;i<N;i++) { for(j=0;j<N;j++) { a[i][j]=b[i][j]; } } cout<<"转置后的矩阵"<<endl; for(i=0;i<rows;i++) { for(j=0;j<cols;j++) { cout<<a[i][j]<<" "; } cout<<endl; } } int main(int argc, char** argv) { int rows=0,cols=0; int i=0,j=0; cout<<"请输入行数和列数"<<endl; cin>>rows>>cols; int a[rows][cols]={0}; cout<<"请输入矩阵元素"<<endl; for(i=0;i<rows;i++) { for(j=0;j<cols;j++) { cin>>a[i][j]; cout<<a[i][j]<<" "; } cout<<endl; } matrixTranspose(a,rows,cols); return 0; } ```

C语言调用函数实现矩阵自乘

各位前辈,小弟新学C语言,怎么也调试不过,不知道哪里出了问题,请问我该怎么调试? 调用void SelfMul(int A1[][3],int A2[][3],int n)实现3阶矩阵的乘法 #include<stdio.h> //void SelfMul(int A1[][maxSize],int A2[][maxSize],int n) void SelfMul(int A1[][3],int A2[][3],int n) { int s=0; for(int i=0;i<n;i++) for(int j=0;j<n;j++) { A2[i][j]=0; for(int k=0;k<n;k++) A2[i][j]=A2[i][j]+A1[i][k]*A1[k][j]; printf("%d ",A2[i][j]); if(++s%3==0)printf("\n"); } } int main() { int A1[][3]={{0,1,0},{0,0,1},{1,1,0}}; int A2[3][3]; // int s=0; SelfMul(A1[][3],A2[][3],3); //编译问题出错提示所在行 /* for(int m=0;m<3;m++) for(int b=0;b<3;b++) { printf("%d ",A2[m][b]); if(++s%3==0)printf("\n"); } */ return 0; } 编译不通过,提示error C2059: syntax error : ']'

一个c++指针的问题,要求编写一个函数

有这样一个题,要求编写一个函数,以char指针数组和数组中的指针数量作为参数,返回最长字符串的地址。我想请问这个函数的返回值的类型是什么呢?也就是说在声明函数时函数类型应该是 **char *** 还是其他呢?因为我认为 **char *** 指的是返回一个指向单个字符的指针而不是指向字符串的指针,而且这个函数怎么编写呢?以下是我写的源代码,虽然通过了编译,但是在运行时崩溃了 ** **char*** maxn( **char *** arr[],int len) { **char** ***max;** max=arr[0]; for(int i=1;i<len;i++) max=(strlen(max)>strlen(arr[i]))?max:arr[i]; return max; }** 还有,在请求动态分配一个指向字符串的指针数组时,应该是 **(char *) * pt = new (char *) [len]** 还是 (char) * pt = new char [len] 呢,小弟是新手,各位高手勿喷啊

(c语言)编写一个函数,由实参传来一个矩阵 A[M][N],按列输出它每一列上最大值和最小值 的差

``` #include<stdio.h> int main() {void judge(int a[10][10],int m,int n); int m,n; printf("请输入矩阵的行数和列数:\n"); scanf("%d%d",&m,&n); int a[m][n],i,j; printf("enter the matrix:\n"); for(i=0;i<m;i++) for(j=0;j<n;j++) scanf("%d",&a[i][j]); judge(a,m,n); return 0; } void judge(int a[10][10],int m,int n) {int max,min,i,j; for(j=0;j<n;j++) {max=a[0][j];min=a[0][j]; for(i=1;i<m;i++) {if(max<a[i][j]) max=a[i][j]; if(min>a[i][j]) min=a[i][j]; } printf("第%d列最大值和最小值的差是%d\n",j+1,max-min); } } ``` ![图片说明](https://img-ask.csdn.net/upload/201904/26/1556284345_790043.png) 为什么不对,求大佬解答?

如何解决vs 中warning C4154: 删除数组表达式;转换到提供的指针 ?

1.编写并测试3×3 矩阵转置函数, 使用数组保存3×3 矩阵。 2.使用动态内存分配生成动态数组来重新完成上题( n 阶方阵),使用指针实现函数的功能。 ``` #include<iostream> using namespace std; void change(int(*p1)[3]); int main() { int(*p)[3]; p = new int[3][3]; cout << "请输入3x3矩阵的9个元素:" << endl; for (int i = 0; i < 3; i++) { for (int j = 0; j < 3; j++) { cin >> *(*(p+i)+j); } } change(p); cout << "转置后矩阵为:" << endl; for (int i = 0; i < 3; i++) { for (int j = 0; j < 3; j++) { cout << *(*(p + i) + j) << " "; } cout << endl; } for (int i = 0; i < 3; i++) delete[] p[i]; delete[]p; return 0; } void change(int(*p1)[3]) { for (int i = 0; i < 3; i++) { for (int j = 0; j < 3; j++) { if (j > i) { int t = *(*(p1 + i) + j); *(*(p1 + i) + j) = *(*(p1 + j) + i); *(*(p1 + j) + i) = t; } } } } ``` 用vs编译时出现了 > warning C4154: 删除数组表达式;转换到提供的指针 运行时出现 ![图片说明](https://img-ask.csdn.net/upload/202004/22/1587568081_180167.jpg) 我发现问题是出在 > for (int i = 0; i < 3; i++) > delete[] p[i]; 因为注释这两行后问题就都没了…… 有无更好的解决办法?

为什么要多输入一个数才能运行,我不是规定了数组只有9个数了吗?

#include <stdio.h> #include <stdlib.h> #define N 3 #define M 3 /*238-4.编写一个函数(参数用指针)将一个3×3矩阵转置。*/ /*与题目无关代码还没写完的*/ void display(int (*p)[M]) { int i,j; for(i=0;i<N;i++) { for(j=0;j<M;j++) { printf("%2d",*(*(p+i)+j)); } printf("\n"); } } int main() { int i,j,(*p)[M],a[N][M]={0}; for(i=0;i<N;i++) { for(j=0;j<M;j++) { scanf("%d ",&a[i][j]); } } p=a; display(p); return 0; } ![图片说明](https://img-ask.csdn.net/upload/201912/01/1575186576_993448.png) ``` ```

菜单式系统求大佬帮忙更改

稀疏矩阵的每个结点包含down,right,row,col和value五个域。用单独一个结点表示一个非零项,并将所有结点连接在一起,形成两个循环链表。使得第一个表即行表,把所有结点按照行序(同一行内按列序)用right域链接起来。使得第二个表即列表,把所有结点按照列序(同一列内按行序)用down链接起来。这两个表共用一个头结点。另外,增加一个包含矩阵维数的结点。稀疏矩阵的这种存储表示称为完全链表表式。 实现一个完全链表系统进行稀疏矩阵运算,并分析下列操作函数的计算时间和额外存储空间的开销。 认识和掌握稀疏矩阵的完全链表表示;能够建立并运用这种存储结构 建立一个用户友好、菜单式系统进行下列操作,并使用合当的测试数据测试该系统。 (a) 读取一个稀疏矩阵建立其完全链表表示 (b) 输出一个稀疏矩阵的内容 (c) 删除一个稀疏矩阵 (d) 两个稀疏矩阵相加 (e) 两个稀疏矩阵相减 (f) 两个稀疏矩阵相乘 (g) 稀疏矩阵的转置![图片说明](https://img-ask.csdn.net/upload/201812/24/1545641300_687295.png) 链表上的操作。 #include"pch.h" #include<stdio.h> #include<stdlib.h> #include<iostream> #include<process.h> #define OK 1 #define ERROR 0 #define _CRT_SECURE_NO_WARNINGS using namespace std; typedef int ElemType; struct OLNode { int i, j; //非零元所在行、列 ElemType e;//非零元值 OLNode *right, *down; }; typedef OLNode *OLink; struct CrossList { OLink *rhead, *chead;//行、列表头的头节点 int mu, nu, tu;//矩阵的行、列和非零元个数 }; int Create(CrossList &M) { int i, j, k, m, n, t; ElemType e; OLNode *p, *q; cout<<"请输入稀疏距阵的行数 列数 非零元的个数:"; cin >> m >> n >> t;//scanf("%d%d%d" ,&m, &n, &t); M.mu = m; M.nu = n; M.tu = t; M.rhead = (OLink*)malloc((m + 1) * sizeof(OLink)); if (!M.rhead) exit(OVERFLOW); M.chead = (OLink*)malloc((n + 1) * sizeof(OLink)); if (!M.chead) exit(OVERFLOW); for (k = 0; k != m; k++)//初始化行头指针 M.rhead[k] = NULL; for (k = 0; k != n; k++)//初始化列头指针 M.chead[k] = NULL; printf("请按任意次序输入%d个非零元的行 列 元素值:\n", M.tu); for (k = 0; k < t; k++) { scanf_s("%d%d%d", &i, &j, &e); if (i > m || j > n) { printf("你输入的元素不在矩阵中 请检查重输:\n"); exit(OVERFLOW); } else { p = (OLNode*)malloc(sizeof(OLNode)); if (!p) exit(OVERFLOW); p->i = i; p->j = j; p->e = e; if (M.rhead[i] == NULL || M.rhead[i]->j > j)//p插入该行第一节点处 { p->right = M.rhead[i]; M.rhead[i] = p; } else//寻找行表插入位置 { for (q = M.rhead[i]; q->right&&q->right->j < j; q = q->right); p->right = q->right;//完成行插入 q->right = p; } if (M.chead[j] == NULL || M.chead[j]->i > i)//p插入该列第一节点处 { p->down = M.chead[j]; M.chead[j] = p; } else//寻找列表插入位置 { for (q = M.chead[j]; q->down&&q->down->i < i; q = q->down); p->down = q->down;//完成列插入 q->down = p; } } } return OK; } int Print(CrossList M) { int i, j, k; OLink p; int array[100][100]; for (i = 0; i != M.mu; i++) { for (j = 0; j != M.nu; j++) { array[i][j] = 0;//初始化数组所需部分 } } for (k = 0; k != M.nu; k++) { p = M.chead[k]; while (p) { array[p->i][p->j] = p->e;//将非零元存入数组中 p = p->down; } } for (i = 0; i != M.mu; i++) { for (j = 0; j != M.nu; j++) { if (j == M.nu - 1) cout << array[i][j] << endl; else cout << array[i][j] << " ";//以矩阵的显示方式显示稀疏矩阵 } } return OK; } int Add(CrossList M, CrossList N, CrossList &Q) { int i, k; OLink p, pq, pm, pn; OLink *col; pq=NULL;//******************************************************************************************** Q.mu = M.mu;//初始化Q Q.nu = M.nu; Q.tu = 0; Q.rhead = (OLink*)malloc((Q.mu + 1) * sizeof(OLink)); if (!Q.rhead) exit(OVERFLOW); Q.chead = (OLink*)malloc((Q.nu + 1) * sizeof(OLink)); if (!Q.chead) exit(OVERFLOW); for (k = 0; k != Q.mu; k++)//初始化行 Q.rhead[k] = NULL; for (k = 0; k != Q.nu; k++)//初始化列 Q.chead[k] = NULL; col = (OLink*)malloc((Q.nu + 1) * sizeof(OLink));//生成指向列的最后节点的数组 if (!col) exit(OVERFLOW); for (k = 0; k != Q.nu; k++)//赋初始值 col[k] = NULL; for (i = 0; i != M.mu; i++)//按行序相加 { pm = M.rhead[i]; pn = N.rhead[i]; while (pm&&pn) { if (pm->j < pn->j)//矩阵M当情前结点的列小于矩阵N当前结点的列 { p = (OLink)malloc(sizeof(OLNode));//生成Q的结点 if (!p) exit(OVERFLOW); Q.tu++; //非零元个数+1 p->i = i; //赋值 p->j = pm->j; p->e = pm->e; p->right = NULL; pm = pm->right; //pm右移 } else if (pm->j > pn->j) { p = (OLink)malloc(sizeof(OLNode)); if (!p) exit(OVERFLOW); Q.tu++; p->i = i; p->j = pn->j; p->e = pn->e; p->right = NULL; pn = pn->right; } else if (pm->e + pn->e)//M,N当前结点的列相同并且两元素之和非零 { p = (OLink)malloc(sizeof(OLNode)); if (!p) exit(OVERFLOW); Q.tu++; p->i = i; p->j = pn->j; p->e = pm->e + pn->e; p->right = NULL; pm = pm->right;//pm右移 pn = pn->right;//pn右移 } else//两元素相加为零 { pm = pm->right; pn = pn->right; continue; } if (Q.rhead[i] == NULL) Q.rhead[i] = pq = p; else { pq->right = p;//完成行插入 pq = pq->right; } if (Q.chead[p->j] == NULL) Q.chead[p->j] = col[p->j] = p; else { col[p->j]->down = p;//完成列插入 col[p->j] = col[p->j]->down; } } while (pm)//将矩阵M该行的剩余元素插入矩阵Q { p = (OLink)malloc(sizeof(OLNode)); if (!p) exit(OVERFLOW); Q.tu++; p->i = i; p->j = pm->j; p->e = pm->e; p->right = NULL; pm = pm->right; if (Q.rhead[i] == NULL) Q.rhead[i] = pq = p; else { pq->right = p; pq = pq->right; } if (Q.chead[p->j] == NULL) Q.chead[p->j] = col[p->j] = p; else { col[p->j]->down = p; col[p->j] = col[p->j]->down; } } while (pn)//将矩阵N该行的剩余元素插入矩阵Q { p = (OLink)malloc(sizeof(OLNode)); if (!p) exit(OVERFLOW); Q.tu++; p->i = i; p->j = pn->j; p->e = pn->e; p->right = NULL; pn = pn->right; if (Q.rhead[i] == NULL) Q.rhead[i] = pq = p; else { pq->right = p; pq = pq->right; } if (Q.chead[p->j] == NULL) Q.chead[p->j] = col[p->j] = p; else { col[p->j]->down = p; col[p->j] = col[p->j]->down; } } } for (k = 0; k != Q.nu; k++) if (col[k]) col[k]->down = NULL; free(col); return OK; } CrossList Negative(CrossList M) { OLink p; for (int j = 0; j != M.mu; j++) { p = M.rhead[j]; while (p) { p->e = -p->e;//将非零元的值反号 p = p->right; } } return (M); } int Mult(CrossList M, CrossList N, CrossList &Q) { int i, j, e; OLink q, p0, q0, q1, q2; q1 = NULL; if (M.nu != N.mu) { printf("你输入的两个距阵不能进行此操作\n"); exit(OVERFLOW); } else { Q.mu = M.mu; Q.nu = N.nu; Q.tu = 0; Q.rhead = (OLink*)malloc((Q.mu + 1) * sizeof(OLink)); if (!Q.rhead) exit(OVERFLOW); Q.chead = (OLink*)malloc((Q.nu + 1) * sizeof(OLink)); if (!Q.chead) exit(OVERFLOW); for (i = 0; i != Q.mu; i++)//初始化行 Q.rhead[i] = NULL; for (i = 0; i != Q.nu; i++)//初始化列 Q.chead[i] = NULL; for (i = 0; i != Q.mu; i++) for (j = 0; j != Q.nu; j++) { p0 = M.rhead[i]; q0 = N.chead[j]; e = 0; while (p0&&q0) { if (q0->i < p0->j) q0 = q0->down;//列后移 else if (q0->i > p0->j) p0 = p0->right;//行后移 else { e = e + p0->e*q0->e;//乘积累加 q0 = q0->down; p0 = p0->right;//行列后移 } } if (e)//e不为零则插入Q { Q.tu++; q = (OLink)malloc(sizeof(OLNode)); if (!q) exit(OVERFLOW); q->i = i; q->j = j; q->e = e; q->right = NULL; q->down = NULL; if (!Q.rhead[i]) Q.rhead[i] = q1 = q; else q1 = q1->right = q; if (!Q.chead[j]) Q.chead[j] = q; else { q2 = Q.chead[j]; while (q2->down) q2 = q2->down; q2->down = q; } } } return OK; } } int main() { CrossList A, B, C;//声明三各矩阵 int Select; cout << "请选择你需要的操作" << endl; cout << "1 加法" << endl; cout << "2 减法" << endl; cout << "3 乘法" << endl; cin >> Select; switch (Select) { case 1://稀疏矩阵相加 { Create(A); Create(B); cout << "你输入的是" << endl; Print(A); cout << "加上" << endl; Print(B); Add(A, B, C); cout << "结果是" << endl; Print(C); break; } case 2://稀疏矩阵相减 { Create(A); Create(B); cout << "你输入的是" << endl; Print(A); cout << "减去" << endl; Print(B); Negative(B); Add(A, B, C); cout << "结果是" << endl; Print(C); break; } case 3://稀疏矩阵相乘 { Create(A); Create(B); cout << "你输入的是" << endl; Print(A); cout << "乘以" << endl; Print(B); Mult(A, B, C); cout << "结果是" << endl; Print(C); break; } } } ``` ```

初级玩转Linux+Ubuntu(嵌入式开发基础课程)

课程主要面向嵌入式Linux初学者、工程师、学生 主要从一下几方面进行讲解: 1.linux学习路线、基本命令、高级命令 2.shell、vi及vim入门讲解 3.软件安装下载、NFS、Samba、FTP等服务器配置及使用

我以为我对Mysql事务很熟,直到我遇到了阿里面试官

太惨了,面试又被吊打

Python代码实现飞机大战

文章目录经典飞机大战一.游戏设定二.我方飞机三.敌方飞机四.发射子弹五.发放补给包六.主模块 经典飞机大战 源代码以及素材资料(图片,音频)可从下面的github中下载: 飞机大战源代码以及素材资料github项目地址链接 ————————————————————————————————————————————————————————— 不知道大家有没有打过飞机,喜不喜欢打飞机。当我第一次接触这个东西的时候,我的内心是被震撼到的。第一次接触打飞机的时候作者本人是身心愉悦的,因为周边的朋友都在打飞机, 每

Python数据分析与挖掘

92讲视频课+16大项目实战+源码+¥800元课程礼包+讲师社群1V1答疑+社群闭门分享会=99元 &nbsp; 为什么学习数据分析? &nbsp; &nbsp; &nbsp; 人工智能、大数据时代有什么技能是可以运用在各种行业的?数据分析就是。 &nbsp; &nbsp; &nbsp; 从海量数据中获得别人看不见的信息,创业者可以通过数据分析来优化产品,营销人员可以通过数据分析改进营销策略,产品经理可以通过数据分析洞察用户习惯,金融从业者可以通过数据分析规避投资风险,程序员可以通过数据分析进一步挖掘出数据价值,它和编程一样,本质上也是一个工具,通过数据来对现实事物进行分析和识别的能力。不管你从事什么行业,掌握了数据分析能力,往往在其岗位上更有竞争力。 &nbsp;&nbsp; 本课程共包含五大模块: 一、先导篇: 通过分析数据分析师的一天,让学员了解全面了解成为一个数据分析师的所有必修功法,对数据分析师不在迷惑。 &nbsp; 二、基础篇: 围绕Python基础语法介绍、数据预处理、数据可视化以及数据分析与挖掘......这些核心技能模块展开,帮助你快速而全面的掌握和了解成为一个数据分析师的所有必修功法。 &nbsp; 三、数据采集篇: 通过网络爬虫实战解决数据分析的必经之路:数据从何来的问题,讲解常见的爬虫套路并利用三大实战帮助学员扎实数据采集能力,避免没有数据可分析的尴尬。 &nbsp; 四、分析工具篇: 讲解数据分析避不开的科学计算库Numpy、数据分析工具Pandas及常见可视化工具Matplotlib。 &nbsp; 五、算法篇: 算法是数据分析的精华,课程精选10大算法,包括分类、聚类、预测3大类型,每个算法都从原理和案例两个角度学习,让你不仅能用起来,了解原理,还能知道为什么这么做。

如何在虚拟机VM上使用串口

在系统内核开发中,经常会用到串口调试,利用VMware的Virtual Machine更是为调试系统内核如虎添翼。那么怎么搭建串口调试环境呢?因为最近工作涉及到这方面,利用强大的google搜索和自己

程序员的兼职技能课

获取讲师答疑方式: 在付费视频第一节(触摸命令_ALL)片头有二维码及加群流程介绍 限时福利 原价99元,今日仅需39元!购课添加小助手(微信号:csdn590)按提示还可领取价值800元的编程大礼包! 讲师介绍: 苏奕嘉&nbsp;前阿里UC项目工程师 脚本开发平台官方认证满级(六级)开发者。 我将如何教会你通过【定制脚本】赚到你人生的第一桶金? 零基础程序定制脚本开发课程,是完全针对零脚本开发经验的小白而设计,课程内容共分为3大阶段: ①前期将带你掌握Q开发语言和界面交互开发能力; ②中期通过实战来制作有具体需求的定制脚本; ③后期将解锁脚本的更高阶玩法,打通任督二脉; ④应用定制脚本合法赚取额外收入的完整经验分享,带你通过程序定制脚本开发这项副业,赚取到你的第一桶金!

MFC一站式终极全套课程包

该套餐共包含从C小白到C++到MFC的全部课程,整套学下来绝对成为一名C++大牛!!!

C++语言基础视频教程

C++语言基础视频培训课程:本课与主讲者在大学开出的程序设计课程直接对接,准确把握知识点,注重教学视频与实践体系的结合,帮助初学者有效学习。本教程详细介绍C++语言中的封装、数据隐藏、继承、多态的实现等入门知识;主要包括类的声明、对象定义、构造函数和析构函数、运算符重载、继承和派生、多态性实现等。 课程需要有C语言程序设计的基础(可以利用本人开出的《C语言与程序设计》系列课学习)。学习者能够通过实践的方式,学会利用C++语言解决问题,具备进一步学习利用C++开发应用程序的基础。

北京师范大学信息科学与技术学院笔试10复试真题

北京师范大学信息科学与技术学院笔试,可以更好的让你了解北师大该学院的复试内容,获得更好的成绩。

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

网络工程师小白入门--【思科CCNA、华为HCNA等网络工程师认证】

本课程适合CCNA或HCNA网络小白同志,高手请绕道,可以直接学习进价课程。通过本预科课程的学习,为学习网络工程师、思科CCNA、华为HCNA这些认证打下坚实的基础! 重要!思科认证2020年2月24日起,已启用新版认证和考试,包括题库都会更新,由于疫情原因,请关注官网和本地考点信息。题库网络上很容易下载到。

Python界面版学生管理系统

前不久上传了一个控制台版本的学生管理系统,这个是Python界面版学生管理系统,这个是使用pycharm开发的一个有界面的学生管理系统,基本的增删改查,里面又演示视频和完整代码,有需要的伙伴可以自行下

软件测试2小时入门

本课程内容系统、全面、简洁、通俗易懂,通过2个多小时的介绍,让大家对软件测试有个系统的理解和认识,具备基本的软件测试理论基础。 主要内容分为5个部分: 1 软件测试概述,了解测试是什么、测试的对象、原则、流程、方法、模型;&nbsp; 2.常用的黑盒测试用例设计方法及示例演示;&nbsp; 3 常用白盒测试用例设计方法及示例演示;&nbsp; 4.自动化测试优缺点、使用范围及示例‘;&nbsp; 5.测试经验谈。

Tomcat服务器下载、安装、配置环境变量教程(超详细)

未经我的允许,请不要转载我的文章,在此郑重声明!!! 请先配置安装好Java的环境,若没有安装,请参照我博客上的步骤进行安装! 安装Java环境教程https://blog.csdn.net/qq_40881680/article/details/83585542 Tomcat部署Web项目(一)·内嵌https://blog.csdn.net/qq_40881680/article/d...

2019数学建模A题高压油管的压力控制 省一论文即代码

2019数学建模A题高压油管的压力控制省一完整论文即详细C++和Matlab代码,希望对同学们有所帮助

图书管理系统(Java + Mysql)我的第一个完全自己做的实训项目

图书管理系统 Java + MySQL 完整实训代码,MVC三层架构组织,包含所有用到的图片资源以及数据库文件,大三上学期实训,注释很详细,按照阿里巴巴Java编程规范编写

linux下利用/proc进行进程树的打印

在linux下利用c语言实现的进程树的打印,主要通过/proc下的目录中的进程文件,获取status中的进程信息内容,然后利用递归实现进程树的打印

微信小程序开发实战之番茄时钟开发

微信小程序番茄时钟视频教程,本课程将带着各位学员开发一个小程序初级实战类项目,针对只看过官方文档而又无从下手的开发者来说,可以作为一个较好的练手项目,对于有小程序开发经验的开发者而言,可以更好加深对小程序各类组件和API 的理解,为更深层次高难度的项目做铺垫。

[已解决]踩过的坑之mysql连接报“Communications link failure”错误

目录 前言 第一种方法: 第二种方法 第三种方法(适用于项目和数据库在同一台服务器) 第四种方法 第五种方法(项目和数据库不在同一台服务器) 总结 前言 先给大家简述一下我的坑吧,(我用的是mysql,至于oracle有没有这样的问题,有心的小伙伴们可以测试一下哈), 在自己做个javaweb测试项目的时候,因为买的是云服务器,所以数据库连接的是用ip地址,用IDE开发好...

人工智能-计算机视觉实战之路(必备算法+深度学习+项目实战)

系列课程主要分为3大阶段:(1)首先掌握计算机视觉必备算法原理,结合Opencv进行学习与练手,通过实际视项目进行案例应用展示。(2)进军当下最火的深度学习进行视觉任务实战,掌握深度学习中必备算法原理与网络模型架构。(3)结合经典深度学习框架与实战项目进行实战,基于真实数据集展开业务分析与建模实战。整体风格通俗易懂,项目驱动学习与就业面试。 建议同学们按照下列顺序来进行学习:1.Python入门视频课程 2.Opencv计算机视觉实战(Python版) 3.深度学习框架-PyTorch实战/人工智能框架实战精讲:Keras项目 4.Python-深度学习-物体检测实战 5.后续实战课程按照自己喜好选择就可以

2019 AI开发者大会

2019 AI开发者大会(AI ProCon 2019)是由中国IT社区CSDN主办的AI技术与产业年度盛会。多年经验淬炼,如今蓄势待发:2019年9月6-7日,大会将有近百位中美顶尖AI专家、知名企业代表以及千余名AI开发者齐聚北京,进行技术解读和产业论证。我们不空谈口号,只谈技术,诚挚邀请AI业内人士一起共铸人工智能新篇章!

机器学习初学者必会的案例精讲

通过六个实际的编码项目,带领同学入门人工智能。这些项目涉及机器学习(回归,分类,聚类),深度学习(神经网络),底层数学算法,Weka数据挖掘,利用Git开源项目实战等。

Python数据分析师-实战系列

系列课程主要包括Python数据分析必备工具包,数据分析案例实战,核心算法实战与企业级数据分析与建模解决方案实战,建议大家按照系列课程阶段顺序进行学习。所有数据集均为企业收集的真实数据集,整体风格以实战为导向,通俗讲解Python数据分析核心技巧与实战解决方案。

YOLOv3目标检测实战系列课程

《YOLOv3目标检测实战系列课程》旨在帮助大家掌握YOLOv3目标检测的训练、原理、源码与网络模型改进方法。 本课程的YOLOv3使用原作darknet(c语言编写),在Ubuntu系统上做项目演示。 本系列课程包括三门课: (1)《YOLOv3目标检测实战:训练自己的数据集》 包括:安装darknet、给自己的数据集打标签、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。 (2)《YOLOv3目标检测:原理与源码解析》讲解YOLOv1、YOLOv2、YOLOv3的原理、程序流程并解析各层的源码。 (3)《YOLOv3目标检测:网络模型改进方法》讲解YOLOv3的改进方法,包括改进1:不显示指定类别目标的方法 (增加功能) ;改进2:合并BN层到卷积层 (加快推理速度) ; 改进3:使用GIoU指标和损失函数 (提高检测精度) ;改进4:tiny YOLOv3 (简化网络模型)并介绍 AlexeyAB/darknet项目。

2021考研数学张宇基础30讲.pdf

张宇:博士,全国著名考研数学辅导专家,教育部“国家精品课程建设骨干教师”,全国畅销书《张宇高等数学18讲》《张宇线性代数9讲》《张宇概率论与数理统计9讲》《张宇考研数学题源探析经典1000题》《张宇考

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

DirectX修复工具V4.0增强版

DirectX修复工具(DirectX Repair)是一款系统级工具软件,简便易用。本程序为绿色版,无需安装,可直接运行。 本程序的主要功能是检测当前系统的DirectX状态,如果发现异常则进行修复

期末考试评分标准的数学模型

大学期末考试与高中的考试存在很大的不同之处,大学的期末考试成绩是主要分为两个部分:平时成绩和期末考试成绩。平时成绩和期末考试成绩总分一般为一百分,然而平时成绩与期末考试成绩所占的比例不同会导致出现不同

Vue.js 2.0之全家桶系列视频课程

基于新的Vue.js 2.3版本, 目前新全的Vue.js教学视频,让你少走弯路,直达技术前沿! 1. 包含Vue.js全家桶(vue.js、vue-router、axios、vuex、vue-cli、webpack、ElementUI等) 2. 采用笔记+代码案例的形式讲解,通俗易懂

c语言项目开发实例

十个c语言案例 (1)贪吃蛇 (2)五子棋游戏 (3)电话薄管理系统 (4)计算器 (5)万年历 (6)电子表 (7)客户端和服务器通信 (8)潜艇大战游戏 (9)鼠标器程序 (10)手机通讯录系统

董付国老师Python全栈学习优惠套餐

购买套餐的朋友可以关注微信公众号“Python小屋”,上传付款截图,然后领取董老师任意图书1本。

2019全国大学生数学建模竞赛C题原版优秀论文

2019全国大学生数学建模竞赛C题原版优秀论文,PDF原版论文,不是图片合成的,是可编辑的文字版。共三篇。 C044.pdf C137.pdf C308.pdf

Git 实用技巧

这几年越来越多的开发团队使用了Git,掌握Git的使用已经越来越重要,已经是一个开发者必备的一项技能;但很多人在刚开始学习Git的时候会遇到很多疑问,比如之前使用过SVN的开发者想不通Git提交代码为什么需要先commit然后再去push,而不是一条命令一次性搞定; 更多的开发者对Git已经入门,不过在遇到一些代码冲突、需要恢复Git代码时候就不知所措,这个时候哪些对 Git掌握得比较好的少数人,就像团队中的神一样,在队友遇到 Git 相关的问题的时候用各种流利的操作来帮助队友于水火。 我去年刚加入新团队,发现一些同事对Git的常规操作没太大问题,但对Git的理解还是比较生疏,比如说分支和分支之间的关联关系、合并代码时候的冲突解决、提交代码前未拉取新代码导致冲突问题的处理等,我在协助处理这些问题的时候也记录各种问题的解决办法,希望整理后通过教程帮助到更多对Git操作进阶的开发者。 本期教程学习方法分为“掌握基础——稳步进阶——熟悉协作”三个层次。从掌握基础的 Git的推送和拉取开始,以案例进行演示,分析每一个步骤的操作方式和原理,从理解Git 工具的操作到学会代码存储结构、演示不同场景下Git遇到问题的不同处理方案。循序渐进让同学们掌握Git工具在团队协作中的整体协作流程。 在教程中会通过大量案例进行分析,案例会模拟在工作中遇到的问题,从最基础的代码提交和拉取、代码冲突解决、代码仓库的数据维护、Git服务端搭建等。为了让同学们容易理解,对Git简单易懂,文章中详细记录了详细的操作步骤,提供大量演示截图和解析。在教程的最后部分,会从提升团队整体效率的角度对Git工具进行讲解,包括规范操作、Gitlab的搭建、钩子事件的应用等。 为了让同学们可以利用碎片化时间来灵活学习,在教程文章中大程度降低了上下文的依赖,让大家可以在工作之余进行学习与实战,并同时掌握里面涉及的Git不常见操作的相关知识,理解Git工具在工作遇到的问题解决思路和方法,相信一定会对大家的前端技能进阶大有帮助。

linux“开发工具三剑客”速成攻略

工欲善其事,必先利其器。Vim+Git+Makefile是Linux环境下嵌入式开发常用的工具。本专题主要面向初次接触Linux的新手,熟练掌握工作中常用的工具,在以后的学习和工作中提高效率。

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

相关热词 c#框体中的退出函数 c# 按钮透明背景 c# idl 混编出错 c#在位置0处没有任何行 c# 循环给数组插入数据 c# 多线程死锁的例子 c# 钉钉读取员工排班 c# label 不显示 c#裁剪影像 c#工作进程更新ui
立即提问