第三周项目四 顺序表应用(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

相关文章

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

python 线程池顺序执行的方法实现

《python线程池顺序执行的方法实现》在Python中,线程池默认是并发执行任务的,但若需要实现任务的顺序执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录方案一:强制单线程(伪顺序执行)方案二:按提交顺序获取结果方案三:任务间依赖控制方案四:队列顺序消

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat

PostgreSQL简介及实战应用

《PostgreSQL简介及实战应用》PostgreSQL是一种功能强大的开源关系型数据库管理系统,以其稳定性、高性能、扩展性和复杂查询能力在众多项目中得到广泛应用,本文将从基础概念讲起,逐步深入到高... 目录前言1. PostgreSQL基础1.1 PostgreSQL简介1.2 基础语法1.3 数据库

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N

Python中yield的用法和实际应用示例

《Python中yield的用法和实际应用示例》在Python中,yield关键字主要用于生成器函数(generatorfunctions)中,其目的是使函数能够像迭代器一样工作,即可以被遍历,但不会... 目录python中yield的用法详解一、引言二、yield的基本用法1、yield与生成器2、yi

Springboot项目构建时各种依赖详细介绍与依赖关系说明详解

《Springboot项目构建时各种依赖详细介绍与依赖关系说明详解》SpringBoot通过spring-boot-dependencies统一依赖版本管理,spring-boot-starter-w... 目录一、spring-boot-dependencies1.简介2. 内容概览3.核心内容结构4.