【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

相关文章

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

MySQL中的索引结构和分类实战案例详解

《MySQL中的索引结构和分类实战案例详解》本文详解MySQL索引结构与分类,涵盖B树、B+树、哈希及全文索引,分析其原理与优劣势,并结合实战案例探讨创建、管理及优化技巧,助力提升查询性能,感兴趣的朋... 目录一、索引概述1.1 索引的定义与作用1.2 索引的基本原理二、索引结构详解2.1 B树索引2.2

如何使用Maven创建web目录结构

《如何使用Maven创建web目录结构》:本文主要介绍如何使用Maven创建web目录结构的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录创建web工程第一步第二步第三步第四步第五步第六步第七步总结创建web工程第一步js通过Maven骨架创pytho

Python循环结构全面解析

《Python循环结构全面解析》循环中的代码会执行特定的次数,或者是执行到特定条件成立时结束循环,或者是针对某一集合中的所有项目都执行一次,这篇文章给大家介绍Python循环结构解析,感兴趣的朋友跟随... 目录for-in循环while循环循环控制语句break语句continue语句else子句嵌套的循

Python+PyQt5实现文件夹结构映射工具

《Python+PyQt5实现文件夹结构映射工具》在日常工作中,我们经常需要对文件夹结构进行复制和备份,本文将带来一款基于PyQt5开发的文件夹结构映射工具,感兴趣的小伙伴可以跟随小编一起学习一下... 目录概述功能亮点展示效果软件使用步骤代码解析1. 主窗口设计(FolderCopyApp)2. 拖拽路径

Python 异步编程 asyncio简介及基本用法

《Python异步编程asyncio简介及基本用法》asyncio是Python的一个库,用于编写并发代码,使用协程、任务和Futures来处理I/O密集型和高延迟操作,本文给大家介绍Python... 目录1、asyncio是什么IO密集型任务特征2、怎么用1、基本用法2、关键字 async1、async

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘