码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • C++初阶作业 Vector作业详解


    作者:@小萌新
    专栏:@C++初阶作业
    作者简介:大二学生 希望能和大家一起进步
    本篇博客介绍:讲解vecotr学校布置的作业 弥补自己不足的知识点
    在这里插入图片描述

    Vector作业详解

    • Vector的特性及使用
      • 题目一 迭代器失效
      • 编程一 只出现一次的数字
      • 编程二 杨辉三角
      • 编程三 删除有序数组中的重复元素
      • 编程四 只出现一次的数字 2
      • 编程四 只出现一次的数字 3
    • Vector oj题
      • 编程一 连续子数组的最大和
      • 编程二 电话号码的排列组合
      • 编程三 数组中出现超过一半的数字
    • 总结

    Vector的特性及使用

    题目一 迭代器失效

    #include <iostream>
    #include 
    using namespace std;
    int main(void)
    
    {
    vector<int>array;
    array.push_back(100);
    array.push_back(300);
    array.push_back(300);
    array.push_back(300);
    array.push_back(300);
    array.push_back(500);
    vector<int>::iterator itor;
    fr(itor=array.begin();itor!=array.end();itor++)
    
    {
    if(* itor==300)
    {
    itor=array.erase(itor);
    }
    }
    for(itor=array.begin();itor!=array.end();itor++)
    {
    cout<<*itor<<" ";
    }
    return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28

    提问 上面的代码输出的会是什么?

    这也是一个经典的迭代器失效的问题我们在删除一个迭代器之后迭代器会指向哪个位置啊?

    是下一个迭代器的位置是吧

    之后再执行++操作

    那么就根据上面几句话看看

    最后的结果是不是就很明显了

    100 300 300 500

    编程一 只出现一次的数字

    考察能力

    1. vector的使用
    2. 异或法的考察

    只出现一次的数字

    这道题对于现在这个阶段来说应该没有任何难度了 全部异或一遍就可以

    编程二 杨辉三角

    考察能力

    1. 对于vector的理解
    2. 画图能力

    对于这些问题 最重要的就是画图找下规律

    在这里插入图片描述

    如果我们将它当成一个数组来看

    第一个数组有一个元素

    第二个数组有两个元素

    第三个数组有三个元素

    第四个数组有四个元素

    …
    第n个数组有n个元素

    继续来看 我们每个数组的第一个元素 以及第n个元素都是1

    其他的元素就是上一个数组对应的数字以及前面一个数字之和

    编程三 删除有序数组中的重复元素

    考察能力

    1. 双指针的使用

    删除数组中的有序元素

    这个题目也很简单 两个指针遍历一趟就可以

    老师出这道题目的用意应该是让我们再熟悉下vector的用法 可以使用下标访问

    编程四 只出现一次的数字 2

    考察能力

    1. 对于位的理解
    2. 对于位运算的理解

    只出现一次的数字二

    一堆数组 只有一个数字出现一次 其他的数字都出现了三次 应该怎么做?

    我们想想看如果是十进制的话 是不是很难算

    但是如果我们将这些数字全部转化为二进制的数字呢?

    假设所有数字全部都出现了3次 或者3的倍数次 那会发生什么现象呢?

    是不是二进制的所有位数相加(无进位) 肯定能够被三整除啊

    那如果加上了我们只出现一次的数字呢?

    是不是就能精准的探测到只出现一次的这个数字它的1应该是再哪里了

    编程四 只出现一次的数字 3

    考察能力

    1. 异或法的使用
    2. 位运算的理解

    只出现一次的数字 3

    这道题目前面有过很详细的题解

    只出现一次的数字题解

    我们将所有数字异或之后只剩下了两个不同数字的异或了

    那么它们的二进制中肯定有一个一(如果全0 那么它们就相同了)

    那么我们找出这个1的位置

    用这个1给这个数组分组异或就好了

    Vector oj题

    编程一 连续子数组的最大和

    考察能力

    1. 动态规划

    连续子数组的最大和

    这个其实就是一个很简单的动态规划问题

    在这里插入图片描述

    我们设置一个dp数组

    表示为当前节点为结尾的最大和

    那我们想想 如果之前的最大和是正数我们是不是只要自身加上前面的最大和就好了

    如果说之前的最大和是负数 我们是不是只要从自身开始就好了

    编程二 电话号码的排列组合

    考察能力

    1. 回溯算法

    一道经典的回溯算法题目

    使用递归回溯逐个遍历每一种组合的可能性即可

    电话号码的排列组合

    编程三 数组中出现超过一半的数字

    考察能力

    1. 哈希表

    数组中出现超过一半的数字

    这一题本来是应该用哈希表来做 但是我们目前还没有学到哈希表这一种数据结构

    所以我是用的数组一一映射的方式来做的和昨天做过的一题

    找出数组中只出现一次的数字差不多

    总结

    vector的作业中难题还是蛮多的

    以后要经常看这些题目多多复习才行

    在这里插入图片描述

    本篇博客主要讲解了vector中的一些作业
    由于作者才疏学浅 错误在所难免 希望大佬看到错误能够及时指正啊
    如果本文帮助到了你 别忘记一键三连啊
    阿尼亚 哇酷哇酷!

  • 相关阅读:
    Nginx虚拟主机的搭建 基于ip 基于端口 基于域名
    教你用canvas打造一个炫酷的碎片切图效果
    获取文件信息: 大小, 文件类型等.
    私有gitlab的搭建和配置教程
    系列学习前端之第 5 章:学习 ES6 ~ ES11
    【S1005基于bs架构的自行车在线租赁管理系统-哔哩哔哩】 https://b23.tv/WJJFGAh
    化工行业数字化供应链系统:赋能化工企业高质量发展,促进上下游协同
    Android动画详解
    kubernetes-如何解决环境变量中敏感信息带来的安全隐患
    写一个带参数的宏MIN(x, y),这个宏输入两个 参数并返回较小的一个。
  • 原文地址:https://blog.csdn.net/meihaoshy/article/details/127952121
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号