数据结构课程设计数据结构课设总结
数据结构课程设计 时间:2021-09-23 阅读:(
)
数据结构课程设计 稀疏矩阵实现与应用
(1)#include <stdio.h>
int main()
{
int i,j,k,num;
int *arr;
printf("输入非0元素的数量:");
scanf("%d",&num);
arr=(int *)malloc(sizeof(int)*(num+1)*3);
for(i=1;i<=num;i++)
{
printf("输入第%d个三元组数据",i);
scanf("%d%d%d",&arr[i*3],&arr[i*3+1],&arr[i*3+2]);
}
for(i=1;i<=num;i++) //获取稀疏矩阵的行和列
{
if(arr[0]<arr[i*3]) arr[0]=arr[i*3]; //保存矩阵的行
if(arr[1]<arr[i*3+1]) arr[1]=arr[i*3+1]; //保存矩阵的列
}
arr[2]=num;//元素数量
printf("稀疏矩阵三元组:
");
for(i=0;i<=num;i++) //输出三元组数据
{
for(j=0;j<3;j++)
printf("%4d", arr[i*3+j]);
printf("
");
}
printf("稀疏矩阵:
");
k=1;
for(i=0;i<=arr[0];i++) //稀疏矩阵的行数
{
for(j=0;j<=arr[1];j++) //稀疏矩阵的列数
{
if(i==arr[k*3] && j==arr[k*3+1] && k<=arr[2])
{
printf("%4d ",arr[k*3+2]); //输出非0数据
k++;
}
else
printf("%4d ", 0); //输出0
}
printf("
");
}
getch();
return 0;
}
三元组形式保存的稀疏矩阵还原为矩阵并输出
(2)#include <stdio.h>
void MatrixMul(int **a,int **b, int **c, int x, int y, int z)
{
int i,j,k;
for (j=0;j<y;j++) //清空目标矩阵C的内容
for(i=0;i<x;i++)
c[j][i]=0;
for(j=0;j<y;j++) //进行矩阵乘法运算
for(i=0;i<x;i++)
for(k=0;k<z;k++)
c[j][i]+= a[j][k]*b[k][i];
}
int main()
{
int i,j,k,tmp;
int ARow,ACol; //矩阵A的行、列
int BRow,BCol; //矩阵B的行、列
int CRow,CCol; //矩阵C的行列
int **a,**b,**c; //分别指向3个矩阵的内存
printf("输入矩阵A的行数和列数:");//输入矩阵A的行数、列数
scanf("%d %d",&ARow,&ACol);
BRow=ACol; //矩阵B的行数等于矩阵A的列数
printf("输入矩阵B的列数:");//输入矩阵B的列数
scanf("%d",&BCol);
CRow=ARow; //目标矩阵C的行数
CCol=BCol; //目标矩阵C的列数
c=(int **)malloc(sizeof(int *)*CRow); //分配保存矩阵C的二级指针存储空间
for(j=0;j<CRow;j++) //分配一级指针内存空间
c[j]=(int *)malloc(sizeof(int)*CCol);
a=(int **)malloc(sizeof(int *)*ARow);//分配保存矩阵A的二级指针
for(j=0;j<ARow;j++)
a[j]=(int *)malloc(sizeof(int)*ACol);
b=(int **)malloc(sizeof(int *)*BRow); //分配保存矩阵B的二级指针
for(j=0;j<BRow;j++)
b[j]=(int *)malloc(sizeof(int)*BCol);
if(!b[BRow-1]) //判断内存是否分配成功
{
printf("分配内存失败!
");
exit(0);
}
printf("输入矩阵A的数据(%d行%d列):
",ARow,ACol);//输入A阵元素
for(j=0;j<ARow;j++)
for (i=0;i<ACol;i++)
{
scanf("%d",&tmp);
a[j][i]=tmp;
}
printf("输入矩阵A的数据(%d行%d列):
",BRow,BCol);//输入B阵元素
for(j=0;j<BRow;j++)
for (i=0;i<BCol;i++)
{
scanf("%d",&tmp);
b[j][i]=tmp;
}
MatrixMul(a,b,c,CCol,CRow,ACol);//调用矩阵乘法函数
printf("矩阵相乘的结果:
");
for(j=0;j<CRow;j++) //输出矩阵乘法结果
{
for(i=0;i<CCol;i++)
printf("%d ",c[j][i]);
printf("
");
}
getch();
return 0;
}
矩阵乘法
(3)
多维矩阵转一维矩阵(以2维为例)
#include <stdio.h>
#include <stdlib.h>
int main()
{
int row, column,i,ARow,ACol,loc,tmp;
int **arr1,*arr2; //分别指向2个矩阵的内存
printf("输入矩阵的行数和列数:");//输入矩阵A的行数、列数
scanf("%d %d",&ARow,&ACol);
arr1=(int **)malloc(sizeof(int *)*ARow); //分配保存矩阵的二级指针存储空间
for(i=0;i<ARow;i++) //分配一级指针内存空间
arr1[i]=(int *)malloc(sizeof(int)*ACol);
arr2=(int *)malloc(sizeof(int)*ARow*ACol);//分配保存一维矩阵的存储空间
if(arr1==NULL) //判断内存是否分配成功
{
printf("分配内存失败!
");
exit(0);
}
printf("输入二维矩阵的数据(%d行%d列):
",ARow,ACol);//输入A阵元素
for(row=0;row<ARow;row++)
for(column=0;column<ACol;column++)
{
scanf("%d",&tmp);
arr1[row][column]=tmp;
}
printf("
以行为主转换为一维矩阵:
");
for(row=0;row<ARow;row++)//按行循环
{
for(column=0;column<ACol;column++) //按列循环
{
loc=column+row*ACol; //转换为一维矩阵的序号
arr2[loc]=arr1[row][column]; //保存元素
}
}
for(i=0;i<ARow*ACol;i++) //输出一维矩阵
printf("%d ", arr2[i]);
printf("
以列为主转换为一维矩阵:
");
for(column=0;column<ACol;column++)
{
for(row=0;row<ARow;row++)
{
loc=row+column*ARow; //转换为一维矩阵的序号
arr2[loc]=arr1[row][column]; //保存元素
}
}
for(i=0;i<ARow*ACol;i++) //输出一维矩阵
printf("%d ", arr2[i]);
printf("
");
getch();
return 0;
}
就这些了不满意也就没办法了数据结构课程设计--一元多项式计算
#include<stdio.h>
#include<malloc.h>
#include<stdlib.h>
typedef struct polynode
{
int coef; //多项式的系数
int exp; //指数
struct polynode *next;
}node;
node *create() //用尾插法建立一元多项式的链表
{
node *h,*r,*s;
int c,e;
h=(node*)malloc(sizeof(node));
r=h;
printf("coef:");
scanf("%d",&c);
printf("exp: ");
scanf("%d",&e);
while(c!=0) //输入系数为0时,多项式的输入结束
{
s=(node*)malloc(sizeof(node));
s->coef=c;
s->exp=e;
r->next=s;
r=s;
printf("coef:");
scanf("%d",&c);
printf("exp: ");
scanf("%d",&e);
}
r->next=NULL;
return(h);
}
void print(node *p) //输出函数,打印出一元多项式
{
while(p->next!=NULL)
{
p=p->next;
printf(" %d*x^%d",p->coef,p->exp);
}
}
void polyadd(node *ha, node *hb)//一元多项式相加函数,用于将两个多项式相加,然后将和多项式存放在多项式ha中,并将多项式hb删除
{
node *p,*q,*pre,*temp;
int sum;
p=ha->next;
q=hb->next;
pre=ha;
while(p!=NULL&&q!=NULL)
{
if(p->exp<q->exp)
{
pre->next=p;
pre=pre->next;
p=p->next;
}
else if(p->exp==q->exp)
{
sum=p->coef+q->coef;
if(sum!=0)
{
p->coef=sum;
pre->next=p;pre=pre->next;p=p->next;
temp=q;q=q->next;free(temp);
}
else //如果系数和为零,则删除结点p与q,并将指针指向下一个结点
{
temp=p->next;free(p);p=temp;
temp=q->next;free(q);q=temp;
}
}
else
{
pre->next=q;
pre=pre->next;
q=q->next;
}
}
if(p!=NULL) //将多项式A中剩余的结点加入到和多项式中
pre->next=p;
else
pre->next=q;
}
void multipoly(node *ha,node *hb)
{ node *p,*q,*n,*m;
p=ha->next;
n=(node*)malloc(sizeof(node));
n->next=NULL;
while(p!=NULL)
{ m=(node*)malloc(sizeof(node));
for(q=hb->next;q;q=q->next)
{ m->coef=p->coef*q->coef;
m->exp=p->exp+q->exp;
m->next=NULL;
}
p=p->next;
polyadd(n,m);
}
printf("多项式的积是:
");
print(n);
}
void main()
{
node *ha,*hb;
printf("请输入多项式ha的系数与指数:
");
ha=create();
print(ha);
printf("
");
printf("请输入多项式hb的系数与指数:
");
hb=create();
print(hb);
printf("
");
printf("多项式的和是:
");
polyadd(ha,hb);
print(ha);
printf("
");
multipoly(ha,hb);
}数据结构课设总结
我正好在做课设,我把我的总结给你。
数据结构是计算机程序设计的重要理论技术基础,它不仅是计算机科学的核心课程,而且也已经成为其他理工专业的热门选修课。
随着高级语言的发展,数据结构在计算机的研究和应用中已展现出强大的生命力,它兼顾了诸多高级语言的特点,是一种典型的结构化程序设计语言,它处理能力强,使用灵活方便,应用面广,具有良好的可移植性。
紧张的两周数据结构实训很快就过去了,通过这两周的实践学习,不仅使我们巩固了以前的知识并在此基础上还对数据结构的特点和算法有了更深的了解,使我们在这门课程的实际应用上也有了一个提高。
首先这两周的学习,使我们在巩固了原有的理论知识上,又培养了灵活运用和组合集成所学过知识及技能来分析、解决实际问题的能力,使我们体会到自身知识和能力在实际中的应用和发挥。
其次,它激发了我们创新意识,开发创造的能力和培养沟通能力。
另外,让我们进一步熟悉了数据结构的设计应用。
每一处编码都是在反复的熟悉数据结构的结构特性,及其语法、函数和程序设计思想的过程,对我们数据结构的学习和提高很有益处,并且使我们明白了程序设计过程,如解决一些实际问题,从解决实际问题的角度,我们可以这样来看:第一要了解这个问题的基本要求,即输入、输出、完成从输入到输出的要求是什么;第二,从问题的要害入手,从前到后的解决问题的每个方面,即从输入开始入手,着重考虑如何从输入导出输出,在这个过程中,可确定所需的数据结构的基本类型——线性表、栈、队列、串、数组、广义表、树和二叉树以及图等,然后确定处理过程——算法,通过在编译环境中的编译与调试,可到最终的程序。
最后,在这次的实训过程中,我们深刻的认识到了自己在学习方面的不足之处,我知道我还有太多的基本的思想没有真正的理解,当然我们不会灰心,我们会在以后的日子里努力弥补我们的不足。
在两周的实训中,我们也体会到了团队合作的重要性,从最初的查阅资料到最后的程序的成功运行,我们组有过山穷水尽的困惑;有过柳暗花明的惊喜;有过唇枪舌剑的辩论;有过相互鼓励的安慰。
两个礼拜的时间我们经历了很多,也收获了很多。
与其说这次的实训是体力与脑力的作业,不如说它是合作精神和毅力的考验。
经过这次课程设计,我们不仅学到了很多知识和技能,更重要的是我们学会了如何运用所学知识去解决实际问题。
总之,两个礼拜的课程设计让我们受益匪浅。
我们深深认识到,要学好一门学科,没有刻苦钻研的精神是不行的,只有在不断的尝试中,经历失败,从失败中总结经验,然后再不断的尝试,才能获得成功。
博鳌云是一家以海外互联网基础业务为主的高新技术企业,运营全球高品质数据中心业务。自2008年开始为用户提供服务,距今11年,在国人商家中来说非常老牌。致力于为中国用户提供域名注册(国外接口)、免费虚拟主机、香港虚拟主机、VPS云主机和香港、台湾、马来西亚等地服务器租用服务,各类网络应用解決方案等领域的专业网络数据服务。商家支持支付宝、微信、银行转账等付款方式。目前香港有一款特价独立服务器正在促销,...
gcorelabs怎么样?gcorelabs是创建于2011年的俄罗斯一家IDC服务商,Gcorelabs提供优质的托管服务和VPS主机服务,Gcorelabs有一支强大的技术队伍,对主机的性能和稳定性要求非常高。Gcorelabs在 2017年收购了SkyparkCDN并提供全球CDN服务,目标是进入全球前五的网络服务商。G-Core Labs总部位于卢森堡,在莫斯科,明斯克和彼尔姆设有办事处。...
LightNode是一家位于香港的VPS服务商.提供基于KVM虚拟化技术的VPS.在提供全球常见节点的同时,还具备东南亚地区、中国香港等边缘节点.满足开发者建站,游戏应用,外贸电商等应用场景的需求。新用户注册充值就送,最高可获得20美元的奖励金!成为LightNode的注册用户后,还可以获得属于自己的邀请链接。通过你的邀请链接带来的注册用户,你将直接获得该用户的消费的10%返佣,永久有效!平台目前...
数据结构课程设计为你推荐
空气污染指数api空气污染指数内蒙古工业大学地址内蒙古工业大学怎么样中山大学南校区地址谁知道中山大学的地址!广西网站建设公司广西网络策划公司视维视频会议Vidyo视频会议好吗交通信号灯控制系统红绿灯工作原理?720云全景制作720度全景是怎样拍的?四川大学教务处四川大学本科生集中在哪个校区北京理工大学图书馆北京理工大学珠海学院图书馆允许外人入内吗?我想进去查些资料.ganesha印度所有的神
抗投诉vps主机 免费申请域名和空间 greengeeks 香港ufo plesk 百度云100as 免备案cdn gitcafe 好看的留言 双11抢红包攻略 css样式大全 国外php空间 日本bb瘦 服务器维护方案 网站cdn加速 asp免费空间申请 域名评估 免费智能解析 google台湾 空间登录首页 更多