第三周项目四 顺序表应用(2)

2024-03-15 11:59
文章标签 应用 项目 顺序 第三周

本文主要是介绍第三周项目四 顺序表应用(2),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

/*   * Copyright (c) 2015, 烟台大学计算机与控制工程学院   * All rights reserved.   * 文件名称:main.cpp,list.cpp,list.h   * 作者:王雪洁  * 完成日期:2015年9月 * 版本号:vc++6.0   *   * 问题描述:将所在奇数移到所有偶数的前面,要求算法的时间复杂度为O(n),空间复杂度为O(1)。* 输入描述:无   * 程序输出:排序后的结果   */ 

list.h

<span style="font-size:14px;">#ifndef LIST_H_INCLUDED  
#define LIST_H_INCLUDED  #define MaxSize 50  
typedef int ElemType;  
typedef struct  
{  ElemType data[MaxSize];  int length;  
} SqList;  
void move(SqList *&L);//移动结束后,奇数居左,偶数居右  
void CreateList(SqList *&L, ElemType a[], int n);//用数组创建线性表  
void InitList(SqList *&L);//初始化线性表InitList(L)  
void DestroyList(SqList *&L);//销毁线性表DestroyList(L)  
bool ListEmpty(SqList *L);//判定是否为空表ListEmpty(L)  
int ListLength(SqList *L);//求线性表的长度ListLength(L)  
void DispList(SqList *L);//输出线性表DispList(L)  
bool GetElem(SqList *L,int i,ElemType &e);//求某个数据元素值GetElem(L,i,e)  
int LocateElem(SqList *L, ElemType e);//按元素值查找LocateElem(L,e)  
bool ListInsert(SqList *&L,int i,ElemType e);//插入数据元素ListInsert(L,i,e)  
bool ListDelete(SqList *&L,int i,ElemType &e);//删除数据元素ListDelete(L,i,e)#endif // LIST_H_INCLUDED  
#endif</span><span style="font-size:18px;"> </span><span style="font-size:14px;"> </span>

list.cpp

<span style="font-size:14px;">#include <stdio.h>  
#include <malloc.h>  
#include "list.h"  //移动结束后,奇数居左,偶数居右  
void move(SqList *&L)  
{  int i=0,j=L->length-1;  ElemType tmp;  while (i<j)  {  while ((i<j) && (L->data[j]%2==0))  //从右往左,找到第一个奇数(偶数就忽略不管)  j--;  while ((i<j) && (L->data[i]%2==1))  //从左往右,找到第一个偶数(奇数就忽略不管)  i++;  if (i<j)   //如果未到达“分界线”,将右边的奇数和左边的偶数交换  {  tmp=L->data[i];  L->data[i]=L->data[j];  L->data[j]=tmp;  }  }   //待循环上去后,继续查找,并在必要时交换  
}  //用数组创建线性表  
void CreateList(SqList *&L, ElemType a[], int n)  
{  int i;  L=(SqList *)malloc(sizeof(SqList));  for (i=0; i<n; i++)  L->data[i]=a[i];  L->length=n;  
}  //初始化线性表InitList(L)  
void InitList(SqList *&L)   //引用型指针  
{  L=(SqList *)malloc(sizeof(SqList));  //分配存放线性表的空间  L->length=0;  
}  //销毁线性表DestroyList(L)  
void DestroyList(SqList *&L)  
{  free(L);  
}  //判定是否为空表ListEmpty(L)  
bool ListEmpty(SqList *L)  
{  return(L->length==0);  
}  //求线性表的长度ListLength(L)  
int ListLength(SqList *L)  
{  return(L->length);  
}  //输出线性表DispList(L)  
void DispList(SqList *L)  
{  int i;  if (ListEmpty(L)) return;  for (i=0; i<L->length; i++)  printf("%d ",L->data[i]);  printf("\n");  
}  //求某个数据元素值GetElem(L,i,e)  
bool GetElem(SqList *L,int i,ElemType &e)  
{  if (i<1 || i>L->length)  return false;  e=L->data[i-1];  return true;  
}  //按元素值查找LocateElem(L,e)  
int LocateElem(SqList *L, ElemType e)  
{  int i=0;  while (i<L->length && L->data[i]!=e) i++;  if (i>=L->length)  return 0;  else  return i+1;  
}  //插入数据元素ListInsert(L,i,e)  
bool ListInsert(SqList *&L,int i,ElemType e)  
{  int j;  if (i<1 || i>L->length+1)  return false;   //参数错误时返回false  i--;            //将顺序表逻辑序号转化为物理序号  for (j=L->length; j>i; j--) //将data[i..n]元素后移一个位置  L->data[j]=L->data[j-1];  L->data[i]=e;           //插入元素e  L->length++;            //顺序表长度增1  return true;            //成功插入返回true  
}  //删除数据元素ListDelete(L,i,e)  
bool ListDelete(SqList *&L,int i,ElemType &e)  
{  int j;  if (i<1 || i>L->length)  //参数错误时返回false  return false;  i--;        //将顺序表逻辑序号转化为物理序号  e=L->data[i];  for (j=i; j<L->length-1; j++) //将data[i..n-1]元素前移  L->data[j]=L->data[j+1];  L->length--;              //顺序表长度减1  return true;              //成功删除返回true  
}  </span>

main.cpp

<span style="font-size:14px;">#include "list.h"  
#include <stdio.h>  //用main写测试代码  
int main()  
{  SqList *sq;  ElemType a[10]= {5,8,7,0,2,4,9,6,7,3};  CreateList(sq, a, 10);  printf("操作前 ");  DispList(sq);  move(sq);    printf("操作后 ");  DispList(sq);  return 0;  
}  </span>

运行结果:


学习心得:

      只有坚持不懈才能看到努力后的成果。

这篇关于第三周项目四 顺序表应用(2)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

一文教你如何将maven项目转成web项目

《一文教你如何将maven项目转成web项目》在软件开发过程中,有时我们需要将一个普通的Maven项目转换为Web项目,以便能够部署到Web容器中运行,本文将详细介绍如何通过简单的步骤完成这一转换过程... 目录准备工作步骤一:修改​​pom.XML​​1.1 添加​​packaging​​标签1.2 添加

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

springboot集成Deepseek4j的项目实践

《springboot集成Deepseek4j的项目实践》本文主要介绍了springboot集成Deepseek4j的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录Deepseek4j快速开始Maven 依js赖基础配置基础使用示例1. 流式返回示例2. 进阶

Java中&和&&以及|和||的区别、应用场景和代码示例

《Java中&和&&以及|和||的区别、应用场景和代码示例》:本文主要介绍Java中的逻辑运算符&、&&、|和||的区别,包括它们在布尔和整数类型上的应用,文中通过代码介绍的非常详细,需要的朋友可... 目录前言1. & 和 &&代码示例2. | 和 ||代码示例3. 为什么要使用 & 和 | 而不是总是使

SpringBoot项目启动报错"找不到或无法加载主类"的解决方法

《SpringBoot项目启动报错找不到或无法加载主类的解决方法》在使用IntelliJIDEA开发基于SpringBoot框架的Java程序时,可能会出现找不到或无法加载主类com.example.... 目录一、问题描述二、排查过程三、解决方案一、问题描述在使用 IntelliJ IDEA 开发基于

Python循环缓冲区的应用详解

《Python循环缓冲区的应用详解》循环缓冲区是一个线性缓冲区,逻辑上被视为一个循环的结构,本文主要为大家介绍了Python中循环缓冲区的相关应用,有兴趣的小伙伴可以了解一下... 目录什么是循环缓冲区循环缓冲区的结构python中的循环缓冲区实现运行循环缓冲区循环缓冲区的优势应用案例Python中的实现库

SpringBoot整合MybatisPlus的基本应用指南

《SpringBoot整合MybatisPlus的基本应用指南》MyBatis-Plus,简称MP,是一个MyBatis的增强工具,在MyBatis的基础上只做增强不做改变,下面小编就来和大家介绍一下... 目录一、MyBATisPlus简介二、SpringBoot整合MybatisPlus1、创建数据库和