【实验五】题解

T1:缺失的数字

题目描述;

我是敦立坤的爹!!!

一个整数集合中含有n个数字,每个数字都在0n之间。假设0n的n+1个数字中有且仅有一个数字不在该集合中,请找出这个数字。


分析:

这里引用一个桶的思想

我们设 a [ x ] a[x] a[x]表示数字x是否出现过

这个时候下标x不再是一个寻常数组的编号,而是一个"值"

里面存放的是数值为x的数字的有关信息(比如是否出现过,出现过几次等等)

利用这种思路,就可以解决这道题


Code

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

int a[10100];

int main(){
    int x;
    cin>>x;
    for (int i = 0,y; i < x; i++)
      cin>>y , a[y] = 1;//出现了一个数字y,就标记一下 
    for (int i = 0; i <= x; i++)
      if (!a[i]) cout<<i;//如果当前数字没出现过就输出 
    return 0;
}

T2:查找最长单词

题目分析:

在进行文章重复度检查时,经常需要统计一段英文中的单词数量,并找出长度最长的单词。


分析:

以空格为分隔,找出单词即可。

并求出长度最长的单词

注意需要在字符串后面加上一个空格,确保能取出最后一个单词


Code

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

string s;
int Max = 0;
string Maxx = "";
int num = 0;

int main(){
    getline(cin,s);s+=' ';//加空格 
    string now = "";
    for (int i = 0 ; i < s.size(); i++)
      if (s[i] == ' '){
          num++;//出现次数加一 
          if (Max < now.size()) Max = now.size() , Maxx = now;//纪录最大 
          now = "";
       } 
       else now+=s[i];//加上 
    cout<<num<<' '<<Max<<' '<<Maxx;
    return 0;
}

T3:到底买不买

题目描述:

太长了不管了


分析:

相关推荐
得物技术2 分钟前
项目性能优化实践:深入FMP算法原理探索|得物技术
前端·算法
FMRbpm4 分钟前
STL中栈的实现
数据结构·c++·算法
roman_日积跬步-终至千里6 分钟前
【模式识别与机器学习(3)】主要算法与技术(中篇:概率统计与回归方法)之贝叶斯方法(Bayesian)
算法·机器学习·回归
AI科技星9 分钟前
加速正电荷产生的电场、引力场与磁场变化率方向关系的数学求导验证——基于张祥前统一场论核心方程
数据结构·人工智能·经验分享·算法·机器学习·计算机视觉
zore_c32 分钟前
【C语言】文件操作详解1(文件的打开与关闭)
c语言·开发语言·数据结构·c++·经验分享·笔记·算法
资深web全栈开发34 分钟前
[特殊字符] LeetCode 2141:如何让 N 台电脑续航最久?——“二分答案“套路一文讲透
算法·leetcode
刃神太酷啦39 分钟前
C++的IO流和C++的类型转换----《Hello C++ Wrold!》(29)--(C/C++)
java·c语言·开发语言·c++·qt·算法·leetcode
稚辉君.MCA_P8_Java40 分钟前
Gemini永久会员 哈希表(Hash Table)高效的数据结构
java·数据结构·后端·算法·架构
Teroin41 分钟前
LeetCode55 跳跃游戏
数据结构·算法·leetcode
summer__777743 分钟前
【期末复习01】-算法题ProgramDesign
java·算法