【MOOC-浙大数据结构】第二周的编程作业——线性结构

2024-03-29 12:58

本文主要是介绍【MOOC-浙大数据结构】第二周的编程作业——线性结构,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第二周的编程作业:

1.两个有序链表序列的合并

List Merge( List L1, List L2 )
{List Res,tmp,pa,pb;	Res=(List)malloc(sizeof(struct Node));pa=L1->Next;pb=L2->Next;tmp=Res;while(pa&&pb){if(pa->Data<=pb->Data){tmp->Next=pa;tmp=pa;pa=pa->Next;}else{tmp->Next=pb;tmp=pb;pb=pb->Next;}}tmp->Next=pa?pa:pb;L1->Next=NULL;L2->Next=NULL;return Res;
}

2.一元多项式的乘法与加法运算

//写了好久

//来自退休老阿姨的挣扎

#include <stdio.h>
#include <stdlib.h>
typedef struct PolyNode *PolyNomial;
struct PolyNode{int coef;int expon;PolyNomial link;
};void Attach(int c,int e,PolyNomial *pRear)
{PolyNomial P=(PolyNomial)malloc(sizeof(struct PolyNode));P->coef=c;P->expon=e;P->link=NULL;(*pRear)->link=P;*pRear=P;
} 
PolyNomial ReadPoly()
{PolyNomial P,Rear,t;P=(PolyNomial)malloc(sizeof(struct PolyNode));P->link=NULL;Rear=P;int n,c,e;scanf("%d",&n);while(n--){scanf("%d%d",&c,&e);Attach(c,e,&Rear);}t=P;P=P->link;free(t);//不要头结点 return P;
}
PolyNomial Mult(PolyNomial P1,PolyNomial P2)
{if(!P1||!P2)return NULL;	//测试点4-判断两个多项式都不为零多项式PolyNomial P,Rear,t1,t2,t;P=(PolyNomial)malloc(sizeof(struct PolyNode));P->link=NULL;Rear=P;t1=P1;t2=P2;while(t2){Attach(t1->coef*t2->coef,t1->expon+t2->expon,&Rear);t2=t2->link;}t1=t1->link;while(t1){t2=P2;Rear=P;while(t2){int c=t1->coef*t2->coef;int e=t1->expon+t2->expon;while(Rear->link&&Rear->link->expon > e){Rear=Rear->link;}if(Rear->link&&Rear->link->expon==e){if(Rear->link->coef+c!=0)	{Rear->link->coef+=c;}else{							Rear->link->coef=0;Rear->link->expon=0;}}else{t=(PolyNomial)malloc(sizeof(PolyNode));t->coef=c;t->expon=e;t->link=Rear->link;Rear->link=t;Rear=Rear->link;}			t2=t2->link;}		t1=t1->link;}Rear=P;P=P->link;free(Rear);return P;
}
PolyNomial Add(PolyNomial P1,PolyNomial P2)
{PolyNomial P,Rear,t1,t2;P=(PolyNomial)malloc(sizeof(struct PolyNode));P->link=NULL;Rear=P;t1=P1;t2=P2;while(t1&&t2){if(t1->expon==t2->expon){if((t1->coef+t2->coef)==0){t1=t1->link;t2=t2->link;}else{Attach(t1->coef+t2->coef,t1->expon,&Rear);t1=t1->link;t2=t2->link;}} else if(t1->expon > t2->expon){Attach(t1->coef,t1->expon,&Rear);t1=t1->link;}else if(t1->expon < t2->expon){Attach(t2->coef,t2->expon,&Rear);t2=t2->link;}}while(t1){Attach(t1->coef,t1->expon,&Rear);t1=t1->link;}while(t2){Attach(t2->coef,t2->expon,&Rear);t2=t2->link;}Rear=P;P=P->link;free(Rear);return P;
}
void PrintPoly(PolyNomial P)
{if(!P)printf("0 0\n");else{while(P){printf("%d %d",P->coef,P->expon);P=P->link;if(P)		printf(" ");}printf("\n");}
}
int main()
{PolyNomial P1,P2,PP,PS;P1=ReadPoly();P2=ReadPoly();	PP=Mult(P1,P2);PrintPoly(PP);PS=Add(P1,P2);PrintPoly(PS);
}

3.Reversing Linked List 

//一开始读错题了,以为只要反转K个就好了,没想到是每K个都要翻转5555

//数据点5超时卡了半个小时,心累

然后改成了while就过了,然后再用for交居然也过了,我????

#include<stdio.h>
#include<map>
#include<string>
#include<iostream>
#include<algorithm>
using namespace std;
string s[100005];
int main()
{int n,k,i,j,x,l;string bg,a,b;map<string,int> data;//存data map<string,string> next;//模拟指针 cin>>bg>>n>>k;for(i=0;i<n;i++){cin>>a>>x>>b;data[a]=x;next[a]=b;} l=0;string c=bg;while(1){if(c=="-1")break;s[l++]=c;c=next[c];}for(i=0;i+k<=l;i+=k)reverse(s+i,s+i+k);for(i=0;i<l-1;i++)cout<<s[i]<<" "<<data[s[i]]<<" "<<s[i+1]<<endl;cout<<s[l-1]<<" "<<data[s[l-1]]<<" -1"<<endl;
}

4.Pop Sequence

#include<stdio.h>
#include<stack>
#include<iostream>
using namespace std;
int a[1005];
int main()
{int m,n,l,i,j,k;scanf("%d%d%d",&m,&l,&n);while(n--){		for(i=0;i<l;i++)scanf("%d",&a[i]);stack<int> s;int rs=1;//放入的数字 k=0;//flagfor(i=1;i<=a[0];i++)s.push(rs++);if(s.size()>m)k=1;//爆栈s.pop();for(i=1;i<l;i++){if(!s.empty()){if(a[i]==s.top()){s.pop();}else{for(;rs<=a[i];)s.push(rs++);if(s.size()>m)k=1;//爆栈 if(a[i]==s.top())s.pop();}	}			else{for(;rs<=a[i];)s.push(rs++);			if(s.size()>m)k=1;//爆栈 s.pop();}			}if(!s.empty()||rs!=l+1)//栈不空or数字没有放完 k=1;if(k)printf("NO\n");else printf("YES\n");}
}

 

这篇关于【MOOC-浙大数据结构】第二周的编程作业——线性结构的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/858652

相关文章

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同

PyCharm接入DeepSeek实现AI编程的操作流程

《PyCharm接入DeepSeek实现AI编程的操作流程》DeepSeek是一家专注于人工智能技术研发的公司,致力于开发高性能、低成本的AI模型,接下来,我们把DeepSeek接入到PyCharm中... 目录引言效果演示创建API key在PyCharm中下载Continue插件配置Continue引言

Java中switch-case结构的使用方法举例详解

《Java中switch-case结构的使用方法举例详解》:本文主要介绍Java中switch-case结构使用的相关资料,switch-case结构是Java中处理多个分支条件的一种有效方式,它... 目录前言一、switch-case结构的基本语法二、使用示例三、注意事项四、总结前言对于Java初学者

结构体和联合体的区别及说明

《结构体和联合体的区别及说明》文章主要介绍了C语言中的结构体和联合体,结构体是一种自定义的复合数据类型,可以包含多个成员,每个成员可以是不同的数据类型,联合体是一种特殊的数据结构,可以在内存中共享同一... 目录结构体和联合体的区别1. 结构体(Struct)2. 联合体(Union)3. 联合体与结构体的

C#反射编程之GetConstructor()方法解读

《C#反射编程之GetConstructor()方法解读》C#中Type类的GetConstructor()方法用于获取指定类型的构造函数,该方法有多个重载版本,可以根据不同的参数获取不同特性的构造函... 目录C# GetConstructor()方法有4个重载以GetConstructor(Type[]

PostgreSQL如何查询表结构和索引信息

《PostgreSQL如何查询表结构和索引信息》文章介绍了在PostgreSQL中查询表结构和索引信息的几种方法,包括使用`d`元命令、系统数据字典查询以及使用可视化工具DBeaver... 目录前言使用\d元命令查看表字段信息和索引信息通过系统数据字典查询表结构通过系统数据字典查询索引信息查询所有的表名可

作业提交过程之HDFSMapReduce

作业提交全过程详解 (1)作业提交 第1步:Client调用job.waitForCompletion方法,向整个集群提交MapReduce作业。 第2步:Client向RM申请一个作业id。 第3步:RM给Client返回该job资源的提交路径和作业id。 第4步:Client提交jar包、切片信息和配置文件到指定的资源提交路径。 第5步:Client提交完资源后,向RM申请运行MrAp