今天给同学写5个数据结构算法的题...感觉很有价值的几个题..感兴趣的坐下。。

简介:   1.判断一个顺序表是否对称 2用向量作存储结构,设计以算法仅用一个辅助结点,实现将线性表中的结点循环右移k位的运算 3.已知A【n】中的元素为整形。设计算法将其调整为左右两部分。左边所有元素为奇数,右边所有元素为偶数, 4,设计以算法,逆置带头结点的动态链表L, 5单链表以非递...
 
1.判断一个顺序表是否对称
2用向量作存储结构,设计以算法仅用一个辅助结点,实现将线性表中的结点循环右移k位的运算
3.已知A【n】中的元素为整形。设计算法将其调整为左右两部分。左边所有元素为奇数,右边所有元素为偶数,
4,设计以算法,逆置带头结点的动态链表L,
5单链表以非递减有序排列,设计算法实现在单链表中删去值相同的多余结点,
6假设有两个按元素值递增有序排列的线性表A和B,均以单链表作存储结构,是编写算法将A表和B表归并成一个按元素值递减有序排列的线性表C,并要求利用原表的结点空间存放C
 
 
我写的代码如下
 
1 、
/*
要求 :判断一个顺序表是否对称
*/
#include <iostream>
using namespace std ;
#define MAX_SIZE 200 
template <class T> 
bool  IsSymmetrical(T List[],int length);    //利用模板可以比较任意类型的顺序表
void main()

 int group= 0;
 bool *pGroup=NULL;//保存的是比较的结果
 int *pNum =NULL;  //这里以整形顺序表为例
 int nCount=0 ;//每组数据的个数
 //cout<<"请输入要比较几组数据:"<<endl ;
 cin>>group;
 pGroup=new bool[group] ;  //动态分配数组内存保存对称比较结果
 for(int n=0;n<group;n++)  //循环四次每一次是一个比较结果
 { 
  cin>>nCount ;
  pNum=new int[nCount] ;  //动态为每行数据分配内存
  for(int m=0;m<nCount;m++)  //为刚分配好的数组进行赋值
   cin>>pNum[m]; 
  pGroup[n]=IsSymmetrical(pNum,nCount)  ; //直接将函数返回结果的bool值保存在动态分配的数组中
  delete []pNum ;// 第一组内存使用完毕释放掉 防止内存泄露
 } 
 for(n=0;n<group;n++) //输出是否对称Y  N
 {
  if(pGroup[n])
   cout<<"Y"<<endl ;
  else
   cout<<"N"<<endl ;
 }
 delete []pGroup ;  //最后再次释放堆内存
}
template <class T> 
bool  IsSymmetrical(T List[],int length)    //利用模板可以比较任意类型的顺序表
{  
 int l=0;
 for(int n=0;n<=length-1;n++)
  if(List[n]==List[length-1-n])
   l++ ;
  if(l==length)
   return true ;
  return false ;
}
 
 
 
 
 
2、

/*
要求:用向量作存储结构,设计以算法仅用一个辅助结点,实现将线性表中的结点循环右移k位的运算 

向量即STL中的vector  动态数组

时间原因这里我只弄了一个线性表来循环移动算法在下面注释部分  需要像第一题多组输入的时候只需要将整个实现部分放在一个循环中实现即可
*/
#include <iostream>
#include <vector>
using namespace std ;
#include "windows.h"
struct Node   //节点数据
{
 int data;
};
void main() 
{  
 vector<Node> List;   //向量的定义
 int size ;//接收输入的大小
 cout<<"请输入表中初始数据的个数:"<<endl ;
 cin>>size ;
 Node *pArray=NULL ;//接受输入的数据
 pArray=new Node[size] ;
 for(int n=0;n<size;n++)
 {  
  cout<<"请输入第"<<n+1<<"个节点的数据,一次输入一个回车结束输入:"<<endl ;
  cin>>pArray[n].data ;
  List.push_back(pArray[n]) ;  //插入数据
 }
 vector<Node>::iterator p=List.begin() ;//返回迭代器 我们可以通过迭代器访问vector
 system("cls");//清除屏幕
 cout<<"初始表中数据如下:"<<endl;
 for(n=0;n<size;n++)  //通过迭代器输入表中数据
  cout<<p[n].data<<"   ";
 cout<<endl ;
 cout<<"数据输入完成请输入要向右移动的位置k:"<<endl ;
 int move ;  //要移动的位置
 cin>>move ;
 move=move%size ;  //取模
 Node tem ;
 List.insert(p,move,tem) ;  //在前面插入5个临时节点 
        p=List.begin();  //迭代到第一个节点
 ////////////////////////////////////////算法实现部分
 size=List.size();int m=0; 
 for(n=size-move ,m=0;n<size;n++,m++)  //对插入的节点进行赋值
  p[m]=p[n];
    for(n=0;n<move;n++)
  List.pop_back() ;//pop出尾部元素
    ///////////////////////////////////
 p=List.begin() ;
 cout<<"右移后元素位置:"<<endl;
 for(n=0;n<size;n++)
        cout<<p[n].data<<"   ";
 cout<<endl;
 
}

 
 
 
 
 
 
3、

/*
3.已知A【n】中的元素为整形。设计算法将其调整为左右两部分。左边所有元素为奇数,右边所有元素为偶数,
操作例子
组数    2 
第一组  5(个数)   1 2 3 4 5
结果    1 3 5 2 4    然后根据提示继续输入下一组
      
*/
#include<iostream>
using namespace std;
#define MAX_SIZE 100
void SetArray(int arr[],int length) ;//算法实现函数
void main()
{
 
   cout<<"\t\t\t操作例子 "<<endl<<"\t\t\t组数    2-->回车  "<<endl<<"\t\t\t第一组  5  1 2 3 4 5 -->回车结束"<<endl;
   cout<<"\t\t\t结果输出   1 3 5 2 4 -->显示结果然后继续输入下组"<<endl ;
    int *pArray=NULL;//动态数组指针
 int nCount=0;//每行数组的个数
 int group=0;
 cout<<"请输入组数:"<<endl;
 cin>>group;
 for(int i=0;i<group;i++)
 {
 cout<<"请输入"<<"第"<<i+1<<"组的个数以及数据例如: 5    1 2 3 4 5"<<endl ;
 cin>>nCount;  //输入个数
 pArray=new int[nCount] ;
 for(int n=0;n<nCount;n++)
  cin>>pArray[n];
 SetArray(pArray,nCount);  //调用设置函数  改变奇数偶数位置
 for(n=0;n<nCount;n++)
  cout<<pArray[n]<<" ";
 cout<<endl ;
 delete []pArray ;  //释放堆中内存
 }
 
 
}

void SetArray(int arr[],int length) //算法实现函数
{
 char buf1[MAX_SIZE] ;
 char buf2[MAX_SIZE] ;
 memset(buf1,'*',MAX_SIZE);  //存放奇数
 memset(buf2,'*',MAX_SIZE);//存放偶数
 buf2[MAX_SIZE-1]='\0';
 buf1[MAX_SIZE-1]='\0';  //防止越界
 for(int n=0,m=0,i=0;n<length;n++)
 {
  if(arr[n]%2==0)
  {
   buf2[m]='0'+arr[n];  //保存偶数asc码
   m++ ;

  }
  else
  { 
            buf1[i]='0'+arr[n] ;//保存奇数asc码
   i++;
  }
 }
   for(n=0,m=0,i=0;n<length;n++)
   {
    if(buf1[m]!='*')
    { 
     arr[n]=buf1[m]-'0' ;
     m++;
    
    }
    else
    {
     arr[n]=buf2[i]-'0' ;
     i++;
    }
   }
}

 
 
4、
 

/*
,设计以算法,逆置带头结点的动态链表L,
先创建 链表然后  进行反序
*/
#include <iostream>
using namespace std ;
typedef struct Node   //链表节点
{
 int data  ;
 struct Node*next ;
}*Head,*LinkNode;
Head head;//头结点
int length=0 ;
Head CreatLinkList() ; //自定义带头链表创建函数
void  Reserve(Head head)  ; //反序算法的实现 其实是实现数据的反序
void Show(Head head) ;//显示函数
void main()
{  
 int group ;
 cout<<"请输入要反序的链表组数"<<endl ;
 cin>>group ;
 Head *pLink=new Head[group];  //保存链表头
 cout<<"输入链表的数据,数据之间空格分开,以66666结束每组输入例如:  1 2 3 4 5 66666->回车"<<endl;
 for(int n=0;n<group;n++)
 {  
  head=CreatLinkList();//创建链表
  Reserve(head) ;
  pLink[n]=head ;
     length =0;
 }
 cout<<"反序后:"<<endl;
    cout<<"<------------------------->"<<endl ;
 for( n=0;n<group;n++)
  Show(pLink[n]);
    cout<<"<------------------------->"<<endl ;

  
 }
void  Reserve(Head head)   //反序算法的实现 其实是实现数据的反序
{
 int count=length/2 ;  //比较次数
 LinkNode p1=head,p2=head ;
 int tem ;
 for(int n=0;n<count;n++)
 {        
  for(int m=0;m<length-n-1;m++)
   p2=p2->next ;
  tem=p1->data ;
  p1->data=p2->data ;
  p2->data=tem ;
  p1=p1->next ;
  p2=head ;
 }
}
void Show(Head head) //显示函数
{
 while(head!=NULL)
 {
  cout<<head->data<<" ";
  head=head->next;
 }
 cout<<endl ;
}
Head CreatLinkList()  //自定义带头链表创建函数
{
 LinkNode p1=NULL,p2=NULL,head =NULL ;
 p1=new Node ; 
 head=p1 ;
 p2=p1 ;
 length++;
 cin>>p1->data ;
 if(p1->data==66666)
 {
  delete p1 ; p1=NULL ;  p2=NULL;
  length--;
  return NULL ;
 }
 while(p1->data!=66666)
 {
  p2=p1 ;
  p1=new Node ;
  length++;
  cin>>p1->data ;
  if(p1->data==66666)
  {
   delete p1 ; p1=NULL ;  p2->next=NULL;
   length--;
   return head ;
  }
  p2->next=p1 ;
 }
 
 return head ;
}

 
 
5、
 
 

/*
单链表以非递减有序排列,设计算法实现在单链表中删去值相同的多余结点, 
算法实现 就是用2个循环遍历链表  算法实现在下注释部分
*/
#include <iostream>
using namespace std ;
typedef struct Node   //链表节点
{
 int data  ;
 struct Node*next ;
}*Head,*LinkNode;
Head head ;//头结点
Head CreatLinkList()  ;//自定义带头链表创建函数
void Delete(Head head) ;  //删除重复的节点算法实现部分。。。。
void Show(Head head) ;//显示函数
void main()
{  
 head=CreatLinkList() ;
 system("cls");
 cout<<"表中数据如下:"<<endl;
 Show(head) ;
 Delete(head) ; //删除重复节点
 cout<<"删除重复节点后的链表:"<<endl;
 Show(head) ;
}

Head CreatLinkList()  //自定义带头链表创建函数
{
 LinkNode p1=NULL,p2=NULL,head =NULL ;
 p1=new Node ; 
 head=p1 ;
 p2=p1 ;
 cout<<"请输入链表节点数据,数据间空格分开 输入66666结束输入 例如  1 2 3 4 5 66666"<<endl;
 cin>>p1->data ;
 if(p1->data==66666)
 {
  delete p1 ; p1=NULL ;  p2=NULL;
  return NULL ;
 }
 while(p1->data!=66666)
 {
  p2=p1 ;
  p1=new Node ;
  cin>>p1->data ;
  if(p1->data==66666)
  {
   delete p1 ; p1=NULL ;  p2->next=NULL;
   return head ;
  }
  p2->next=p1 ;
 }
 return head ;
}
/////////////////////////////////////////////////////////////////////////////////
void Delete(Head head)   //删除重复的节点算法实现部分。。。。
{
 Head p1=head,p2=head ; 
 LinkNode tem=NULL ;  //临时节点指针
 while(p1!=NULL)
 {
  while(p2->next!=NULL) //当p2的next到达尾部的时候后就要推出否则  下面p2->next->next会崩溃
  { 
   if(p2->next->data==p1->data)
   {
    tem=p2->next ;
    p2->next=p2->next->next ;
    delete tem ;
    continue ;
   }
   else
   p2=p2->next ;
  }
  p1=p1->next;
  p2=p1 ;
 }
}
///////////////////////////////////////////////////////////////////////////////////
void Show(Head head) //显示函数
{
 while(head!=NULL)
 {
  cout<<head->data<<" ";
  head=head->next;
 }
 cout<<endl ;
}

 
 
6、
/*
6假设有两个按元素值递增有序排列的线性表A和B,均以单链表作存储结构,
是编写算法将A表和B表归并成一个按元素值递减有序排列的线性表C,并要求利用原表的结点空间存放C
<---------在输入数据的时候一定要按递增输入数据 ------>
*/
#include <iostream>
using namespace std ;
typedef struct Node   //链表节点
{
 int data  ;
 struct Node*next ;
}*Head,*LinkNode;
LinkNode A =NULL;//表1
LinkNode B =NULL;//表2
LinkNode C=NULL; //表3
int GetMax(Head head);  //返回链表中的最大数据
Head CreatLinkList()  ;//自定义带头链表创建函数
Head  CombineLinkList(Head A,Head B) ; //合并算法的实现部分
void Show(Head head) ;//显示函数
void main()
{
    cout<<"表A:"<<endl;
 A=CreatLinkList();  //创建表A
    cout<<"表B:"<<endl;
 B=CreatLinkList(); //创建表B
 C=CombineLinkList(A,B) ;
    Show(C);
}
Head  CombineLinkList(Head A,Head B)  //合并算法的实现部分
{
      
   LinkNode tem=A ;
      while(tem->next!=NULL)
   {
    tem=tem->next;
   }
   tem->next=B ;
   C=A  ;//A B 表连接起来 然后 降序排序
   LinkNode p1=C;
      LinkNode p2=C->next;
   int inter=C->data ;//用于交换的临时变量
   while(p1->next!=NULL)
   {
         while(p2!=NULL)
   {
           if(p2->data>p1->data)  //交换数据
     {
      inter=p1->data ;
      p1->data=p2->data;
      p2->data=inter ;
     }
     p2=p2->next ;
   }
    p1=p1->next;
    p2=p1->next;
   }
 return  C;
}
void Show(Head head) //显示链表函数
{
 while(head!=NULL)
 {
  cout<<head->data<<" ";
  head=head->next;
 }
 cout<<endl ;
}
int GetMax(Head head)  //返回链表中的最大数据
{
    while(head->next!=NULL)
  head=head->next ;
 return head->data;
}
Head CreatLinkList()  //自定义带头链表创建函数
{
 LinkNode p1=NULL,p2=NULL,head =NULL ;
 p1=new Node ; 
 head=p1 ;
 p2=p1 ;
 cout<<"请输入链表节点数据,数据间空格分开 输入66666结束输入 例如  1 2 3 4 5 66666"<<endl;
 cin>>p1->data ;
 if(p1->data==66666)
 {
  delete p1 ; p1=NULL ;  p2=NULL;
  return NULL ;
 }
 while(p1->data!=66666)
 {
  p2=p1 ;
  p1=new Node ;
  cin>>p1->data ;
  if(p1->data==66666)
  {
   delete p1 ; p1=NULL ;  p2->next=NULL;
   return head ;
  }
  p2->next=p1 ;
 }
 return head ;
}
 
 
 
 
目录
相关文章
|
2月前
|
算法 数据处理 C语言
C语言中的位运算技巧,涵盖基本概念、应用场景、实用技巧及示例代码,并讨论了位运算的性能优势及其与其他数据结构和算法的结合
本文深入解析了C语言中的位运算技巧,涵盖基本概念、应用场景、实用技巧及示例代码,并讨论了位运算的性能优势及其与其他数据结构和算法的结合,旨在帮助读者掌握这一高效的数据处理方法。
60 1
|
3月前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
106 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
1天前
|
存储 算法 测试技术
【C++数据结构——树】二叉树的遍历算法(头歌教学实验平台习题) 【合集】
本任务旨在实现二叉树的遍历,包括先序、中序、后序和层次遍历。首先介绍了二叉树的基本概念与结构定义,并通过C++代码示例展示了如何定义二叉树节点及构建二叉树。接着详细讲解了四种遍历方法的递归实现逻辑,以及层次遍历中队列的应用。最后提供了测试用例和预期输出,确保代码正确性。通过这些内容,帮助读者理解并掌握二叉树遍历的核心思想与实现技巧。
14 2
|
2月前
|
存储 算法 搜索推荐
Python 中数据结构和算法的关系
数据结构是算法的载体,算法是对数据结构的操作和运用。它们共同构成了计算机程序的核心,对于提高程序的质量和性能具有至关重要的作用
|
2月前
|
数据采集 存储 算法
Python 中的数据结构和算法优化策略
Python中的数据结构和算法如何进行优化?
|
2月前
|
算法
数据结构之路由表查找算法(深度优先搜索和宽度优先搜索)
在网络通信中,路由表用于指导数据包的传输路径。本文介绍了两种常用的路由表查找算法——深度优先算法(DFS)和宽度优先算法(BFS)。DFS使用栈实现,适合路径问题;BFS使用队列,保证找到最短路径。两者均能有效查找路由信息,但适用场景不同,需根据具体需求选择。文中还提供了这两种算法的核心代码及测试结果,验证了算法的有效性。
123 23
|
2月前
|
算法
数据结构之蜜蜂算法
蜜蜂算法是一种受蜜蜂觅食行为启发的优化算法,通过模拟蜜蜂的群体智能来解决优化问题。本文介绍了蜜蜂算法的基本原理、数据结构设计、核心代码实现及算法优缺点。算法通过迭代更新蜜蜂位置,逐步优化适应度,最终找到问题的最优解。代码实现了单链表结构,用于管理蜜蜂节点,并通过适应度计算、节点移动等操作实现算法的核心功能。蜜蜂算法具有全局寻优能力强、参数设置简单等优点,但也存在对初始化参数敏感、计算复杂度高等缺点。
64 20
|
2月前
|
机器学习/深度学习 算法 C++
数据结构之鲸鱼算法
鲸鱼算法(Whale Optimization Algorithm,WOA)是由伊朗研究员Seyedali Mirjalili于2016年提出的一种基于群体智能的全局优化算法,灵感源自鲸鱼捕食时的群体协作行为。该算法通过模拟鲸鱼的围捕猎物和喷出气泡网的行为,结合全局搜索和局部搜索策略,有效解决了复杂问题的优化需求。其应用广泛,涵盖函数优化、机器学习、图像处理等领域。鲸鱼算法以其简单直观的特点,成为初学者友好型的优化工具,但同时也存在参数敏感、可能陷入局部最优等问题。提供的C++代码示例展示了算法的基本实现和运行过程。
64 0
|
3月前
|
机器学习/深度学习 存储 缓存
数据结构与算法学习十:排序算法介绍、时间频度、时间复杂度、常用时间复杂度介绍
文章主要介绍了排序算法的分类、时间复杂度的概念和计算方法,以及常见的时间复杂度级别,并简单提及了空间复杂度。
57 1
数据结构与算法学习十:排序算法介绍、时间频度、时间复杂度、常用时间复杂度介绍
|
2月前
|
算法 vr&ar 计算机视觉
数据结构之洪水填充算法(DFS)
洪水填充算法是一种基于深度优先搜索(DFS)的图像处理技术,主要用于区域填充和图像分割。通过递归或栈的方式探索图像中的连通区域并进行颜色替换。本文介绍了算法的基本原理、数据结构设计(如链表和栈)、核心代码实现及应用实例,展示了算法在图像编辑等领域的高效性和灵活性。同时,文中也讨论了算法的优缺点,如实现简单但可能存在堆栈溢出的风险等。
70 0