python讲师陈越_【数据结构_浙江大学MOOC】第一讲 基本概念

本文主要是介绍python讲师陈越_【数据结构_浙江大学MOOC】第一讲 基本概念,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本系列数据结构专题为中国大学MOOC-陈越、何钦铭-数据结构-2018秋课程的学习记录。主要记录内容为编程题解答。每篇内容将会不定期更新,以补充更好的方法。

函数题

01-复杂度3 二分查找(20 分)

本题要求实现二分查找算法。

函数接口定义:

Position BinarySearch( List L, ElementType X );

其中List结构定义如下:

typedef int Position;

typedef struct LNode *List;

struct LNode {

ElementType Data[MAXSIZE];

Position Last; /* 保存线性表中最后一个元素的位置 */

};

L是用户传入的一个线性表,其中ElementType元素可以通过>、==、

裁判测试程序样例:

#include

#include

#define MAXSIZE 10

#define NotFound 0

typedef int ElementType;

typedef int Position;

typedef struct LNode *List;

struct LNode {

ElementType Data[MAXSIZE];

Position Last; /* 保存线性表中最后一个元素的位置 */

};

List ReadInput(); /* 裁判实现,细节不表。元素从下标1开始存储 */

Position BinarySearch( List L, ElementType X );

int main()

{

List L;

ElementType X;

Position P;

L = ReadInput();

scanf("%d", &X);

P = BinarySearch( L, X );

printf("%d\n", P);

return 0;

}

/* 你的代码将被嵌在这里 */

输入样例1:

5

12 31 55 89 101

31

输出样例1:

2

输入样例2:

3

26 78 233

31

输出样例2:

0

代码

编译器:C (gcc)

Position BinarySearch( List L, ElementType X ){

Position position;

Position left = 0;

Position right = L->Last;

ElementType flag = 0;

while(left <= right){

Position mid = left + (right -left)/2;

if(L->Data[mid] == X){

position = mid;

flag = 1;

break;

}

else if(L->Data[mid] > X){

right = mid-1;

}else{

left = mid+1;

}

}

if(flag == 0)

position = NotFound;

return position;

}

提交结果:

a0cbfc11d204531435543456c37ee2d9.png

编程题

01-复杂度1 最大子列和问题(20 分)

给定K个整数组成的序列 $\{N_1,N_2, ···,N_k \}$,“连续子列”被定义为 $\{N_i,N_{i+1}, ···,N_j \}$,其中 $1≤i≤j≤K$。“最大子列和”则被定义为所有连续子列元素的和中最大者。例如给定序列 { -2, 11, -4, 13, -5, -2 },其连续子列 { 11, -4, 13 } 有最大的和20。现要求你编写程序,计算给定整数序列的最大子列和。

本题旨在测试各种不同的算法在各种数据情况下的表现。各组测试数据特点如下:

数据1:与样例等价,测试基本正确性;

数据2:$10^2$ 个随机整数;

数据3:$10^3$ 个随机整数;

数据4:$10^4$ 个随机整数;

数据5:$10^5$ 个随机整数;

输入格式:

输入第 1 行给出正整数 $K (≤100000)$;第 2 行给出 $K$ 个整数,其间以空格分隔。

输出格式:

在一行中输出最大子列和。如果序列中所有整数皆为负数,则输出 0。

输入样例:

6

-2 11 -4 13 -5 -2

输出样例:

20

代码

编译器:C (gcc)

/*

编程题-01【最大子列和问题】

中国大学MOOC-陈越、何钦铭-数据结构-2018秋

标签:复杂度

2018-09-08

*/

# include

int MaxSubseqSum(int A[], int N);

int main()

{

int numK;

int maxSum;

int k;

scanf("%d", &numK);

int a[numK];

for(k=0; k

scanf("%d", &a[k]);

maxSum = MaxSubseqSum(a, numK);

printf("%d\n", maxSum);

return 0;

}

int MaxSubseqSum (int A[], int N)

{

int thisSum, maxSum;

int i, j;

thisSum = maxSum = 0;

/* 逐个向右累加 */

for( i = 0; i < N; i++) //i 为子列左端位置

{

/* A[i]到A[j]的子列和 */

thisSum = 0;

for(j=i; j

{

/* 对于相同起点的一系列子列和,只需更新终点即可 */

/* 即对于相同的i,不同的j,只需在j-1次循环的基础上累加1项 */

/* 降低了算法复杂度 */

thisSum +=A[j];

/* 当前子列和大于最大子列和,更新 */

if(thisSum > maxSum)

maxSum = thisSum;

/* 当前子列和为负,后面再加子列和不可能变大,故抛弃 */

else if(thisSum < 0)

thisSum = 0;

}

}

return maxSum;

}

提交结果:

6a9872366aae16d433ce8a48b430c3fe.png

01-复杂度2 Maximum Subsequence Sum(25 分)

Given a sequence of $K$ integers $\{N_1,N_2, ···,N_k \}$. A continuous subsequence is defined to be $\{N_i,N_{i+1}, ···,N_j \}$ where $1≤i≤j≤K$ . The Maximum Subsequence is the continuous subsequence which has the largest sum of its elements. For example, given sequence { -2, 11, -4, 13, -5, -2 }, its maximum subsequence is { 11, -4, 13 } with the largest sum being 20.

Now you are supposed to find the largest sum, together with the first and the last numbers of the maximum subsequence.

Input Specification:

Each input file contains one test case. Each case occupies two lines. The first line contains a positive integer $K (≤10000)$. The second line contains $K$ numbers, separated by a space.

Output Specification:

For each test case, output in one line the largest sum, together with the first and the last numbers of the maximum subsequence. The numbers must be separated by one space, but there must be no extra space at the end of a line. In case that the maximum subsequence is not unique, output the one with the smallest indices i and j (as shown by the sample case). If all the $K$ numbers are negative, then its maximum sum is defined to be 0, and you are supposed to output the first and the last numbers of the whole sequence.

Sample Input:

10

-10 1 2 3 4 -5 -23 3 7 -21

Sample Output:

10 1 4

代码

编译器:C++ (g++)

#include

#include

using namespace std;

int main(int argc, const char * argv[])

{

//input

int K;

cin>>K;

vector vec;

int value;

for (int i=0; i

{

cin>>value;

vec.push_back(value);

}

//Process

int first=0,last=0,sum=0,max=-1;

int flag_max=0;//flag represent whether max has been rewrite

int flag=0;//sum归零一次,有可能后续子数列会出现大于当前max的数列

int maybe_first=0;//可能成为最大子列和的第一个结点

for (int i=0; i

{

sum+=vec[i];

if (sum>max)//更新最大子列和

{

flag_max=1;

if (flag==0)//sum更新为0后再次出现大于之前max的最大子列和,更新最大子列和的第一个结点

{

first=maybe_first;

flag=1;

}

max=sum;

last=i;//每次出现新的最大子列和都要更新该子列的最后一个结点

}else if(sum<0)//sum出现小于0的情况,后续子列若出现更大的子列和,则该子列的第一个结点保存为maybe_first

{

maybe_first=i+1;

sum=0;

flag=0;

}

}

//Output

if (flag_max==0)

{

cout<

}else

{

cout<

}

return 0;

}

提交结果:

1a3a02d15f885471a939c8581402f291.png

编译器:Python (python3)

num = int(input())

a = input()

a = a.split(' ')

max = -1

sum = 0

temp = 0

first = 0

last = 0

for i in range(0,num):

sum = sum + int(a[i])

if sum > max:

max = sum

last = i

first = temp

elif sum < 0:

sum = 0

temp = i+1

if(max >= 0):

print(max,a[first],a[last],sep=' ')

else:

print(0,a[0],a[len(a) -1],sep=' ')

提交结果:

af28a52ca99c4bb78913604f700fb13a.png

不足之处,欢迎指正。

$$$$

这篇关于python讲师陈越_【数据结构_浙江大学MOOC】第一讲 基本概念的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python运行中频繁出现Restart提示的解决办法

《Python运行中频繁出现Restart提示的解决办法》在编程的世界里,遇到各种奇怪的问题是家常便饭,但是,当你的Python程序在运行过程中频繁出现“Restart”提示时,这可能不仅仅是令人头疼... 目录问题描述代码示例无限循环递归调用内存泄漏解决方案1. 检查代码逻辑无限循环递归调用内存泄漏2.

Python中判断对象是否为空的方法

《Python中判断对象是否为空的方法》在Python开发中,判断对象是否为“空”是高频操作,但看似简单的需求却暗藏玄机,从None到空容器,从零值到自定义对象的“假值”状态,不同场景下的“空”需要精... 目录一、python中的“空”值体系二、精准判定方法对比三、常见误区解析四、进阶处理技巧五、性能优化

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

python logging模块详解及其日志定时清理方式

《pythonlogging模块详解及其日志定时清理方式》:本文主要介绍pythonlogging模块详解及其日志定时清理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录python logging模块及日志定时清理1.创建logger对象2.logging.basicCo

Python如何自动生成环境依赖包requirements

《Python如何自动生成环境依赖包requirements》:本文主要介绍Python如何自动生成环境依赖包requirements问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录生成当前 python 环境 安装的所有依赖包1、命令2、常见问题只生成当前 项目 的所有依赖包1、

如何将Python彻底卸载的三种方法

《如何将Python彻底卸载的三种方法》通常我们在一些软件的使用上有碰壁,第一反应就是卸载重装,所以有小伙伴就问我Python怎么卸载才能彻底卸载干净,今天这篇文章,小编就来教大家如何彻底卸载Pyth... 目录软件卸载①方法:②方法:③方法:清理相关文件夹软件卸载①方法:首先,在安装python时,下

python uv包管理小结

《pythonuv包管理小结》uv是一个高性能的Python包管理工具,它不仅能够高效地处理包管理和依赖解析,还提供了对Python版本管理的支持,本文主要介绍了pythonuv包管理小结,具有一... 目录安装 uv使用 uv 管理 python 版本安装指定版本的 Python查看已安装的 Python

使用Python开发一个带EPUB转换功能的Markdown编辑器

《使用Python开发一个带EPUB转换功能的Markdown编辑器》Markdown因其简单易用和强大的格式支持,成为了写作者、开发者及内容创作者的首选格式,本文将通过Python开发一个Markd... 目录应用概览代码结构与核心组件1. 初始化与布局 (__init__)2. 工具栏 (setup_t

Python中局部变量和全局变量举例详解

《Python中局部变量和全局变量举例详解》:本文主要介绍如何通过一个简单的Python代码示例来解释命名空间和作用域的概念,它详细说明了内置名称、全局名称、局部名称以及它们之间的查找顺序,文中通... 目录引入例子拆解源码运行结果如下图代码解析 python3命名空间和作用域命名空间命名空间查找顺序命名空

Python如何将大TXT文件分割成4KB小文件

《Python如何将大TXT文件分割成4KB小文件》处理大文本文件是程序员经常遇到的挑战,特别是当我们需要把一个几百MB甚至几个GB的TXT文件分割成小块时,下面我们来聊聊如何用Python自动完成这... 目录为什么需要分割TXT文件基础版:按行分割进阶版:精确控制文件大小完美解决方案:支持UTF-8编码