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

相关文章

Java中的Lambda表达式及其应用小结

《Java中的Lambda表达式及其应用小结》Java中的Lambda表达式是一项极具创新性的特性,它使得Java代码更加简洁和高效,尤其是在集合操作和并行处理方面,:本文主要介绍Java中的La... 目录前言1. 什么是Lambda表达式?2. Lambda表达式的基本语法例子1:最简单的Lambda表

springboot项目如何开启https服务

《springboot项目如何开启https服务》:本文主要介绍springboot项目如何开启https服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录springboot项目开启https服务1. 生成SSL证书密钥库使用keytool生成自签名证书将

将Java项目提交到云服务器的流程步骤

《将Java项目提交到云服务器的流程步骤》所谓将项目提交到云服务器即将你的项目打成一个jar包然后提交到云服务器即可,因此我们需要准备服务器环境为:Linux+JDK+MariDB(MySQL)+Gi... 目录1. 安装 jdk1.1 查看 jdk 版本1.2 下载 jdk2. 安装 mariadb(my

Python结合PyWebView库打造跨平台桌面应用

《Python结合PyWebView库打造跨平台桌面应用》随着Web技术的发展,将HTML/CSS/JavaScript与Python结合构建桌面应用成为可能,本文将系统讲解如何使用PyWebView... 目录一、技术原理与优势分析1.1 架构原理1.2 核心优势二、开发环境搭建2.1 安装依赖2.2 验

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

SpringShell命令行之交互式Shell应用开发方式

《SpringShell命令行之交互式Shell应用开发方式》本文将深入探讨SpringShell的核心特性、实现方式及应用场景,帮助开发者掌握这一强大工具,具有很好的参考价值,希望对大家有所帮助,如... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

MySQL 分区与分库分表策略应用小结

《MySQL分区与分库分表策略应用小结》在大数据量、复杂查询和高并发的应用场景下,单一数据库往往难以满足性能和扩展性的要求,本文将详细介绍这两种策略的基本概念、实现方法及优缺点,并通过实际案例展示如... 目录mysql 分区与分库分表策略1. 数据库水平拆分的背景2. MySQL 分区策略2.1 分区概念