欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

第2章学习小结

程序员文章站 2022-06-19 19:10:19
第2章学习线性表的顺序表示和链式表示,及二者在不同情况下的时间复杂度,空间复杂度。 由于一开始是学习二者的基本操作,要组合起来实际写一个完整程序时,连接处磕磕碰碰,不知从何入手,最后参考老师给的代码学习了基本写法。在一道求逆转链表的填空题时,完全不会,找了各方资料,最后也是在一篇博客中(https: ......

        第2章学习线性表的顺序表示和链式表示,及二者在不同情况下的时间复杂度,空间复杂度。

       由于一开始是学习二者的基本操作,要组合起来实际写一个完整程序时,连接处磕磕碰碰,不知从何入手,最后参考老师给的代码学习了基本写法。在一道求逆转链表的填空题时,完全不会,找了各方资料,最后也是在一篇博客中(https://www.cnblogs.com/puyangsky/p/5337050.html)厘清其中道理。还有在求交集的那道题中,就是由于方法不是最优,pta总是显示运行超时,最后是向同学求助,才学习到了我所没想到的方法。

       大概是目前做题经验不足,在很多问题上要思考许久,另外对代码不太熟悉,不能完全独立打下来,总是翻书看。

       接下来希望写代码可以脱离教材,对代码更熟悉,还有就是在解决问题的时候可以多思考有没有其它思路,是否为最优解。

 

求交集:

 

#include <iostream>
#include <algorithm>
using namespace std;

 

#define maxsize 100000

 

typedef int elemtype;

 

typedef struct
{
 elemtype elem[maxsize];
 int length;
}sqlist;

 

int main()
{
 sqlist a,b,c;                  //定义sqlist类型的变量a,b,c
 int n,m,i=0,j=0;
 int num=0;
 int x=0;
 cin >> n>>m;
 if ( (n > maxsize) || (m > maxsize) )  //n值超出范围,程序退出
 return 0;                     
 
 for ( int i = 0; i < n; i++ ) //输入集合a的元素
  cin >> a.elem[i] ;
 for ( int i = 0; i < m; i++)  //输入集合b的元素
     cin>>b. elem[i];
 sort(a.elem,a.elem+n);        //调用函数sort对集合a进行从小到大排序
 sort(b.elem,b.elem+m);        //调用函数sort对集合b进行从小到大排序
   
 while(i<n && j<m)
 {
  
  if(a.elem[i]<b.elem[j])   //因为集合a,b已经排好序,选择a中下一个不小于当前元素的元素与b当前的元素比较
      i++;
  else if(a.elem[i]>b.elem[j]) //选择集合b中下一个元素与a的当前元素比较大小
      j++;
  else if(a.elem[i]==b.elem[j])
  {
   c.elem[num]=a.elem[i];     //将共有的元素存在集合c中
   num++;
   i++;                    //两集合都向后继续比较
   j++;
   
  }
 }
   
 cout<<num<<endl;             //输出交集中元素的个数
    for(int i=0;i<num;i++)       //输出交集中的元素
    {
     if(i==0)
     {
      cout<<c.elem[i];
  }
  if(i!=0)
  {
   cout<<" "<<c.elem[i];
  }
 }
    return 0;
}