使用vector的一些小问题

7-6 按顺序输出

分数 15

全屏浏览

切换布局

作者 fpc

单位 内蒙古师范大学

本题目要求读入3个整数a,b,c,然后按从小到大的顺序输出。

输入格式:

输入在一行中给出2个绝对值不超过1000的整数a,b,c。

输出格式:

对每一组输入,按照从小到大的顺序在一行内输出两个数,中间用"<"分割(行尾无需换行)。

输入样例:

复制代码
5 3 4

输出样例:

复制代码
3<4<5

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

背景:

今天的作业,想用vector然后sort一下。代码如下。但是运行结果就是"0<0<0"

代码:

#include<bits/stdc++.h>

using namespace std;

int main(){

vector<int>a(4);//

for(int i=0;i<3;i++){

int b;

cin>>b;

a.push_back(b);//

}

sort(a.begin(),a.end());

for(int i=0;i<3;i++){

cout<<a[i];

if(i!=2)cout<<'<';

}

return 0;

}

查了一下gpt确实是有问题:在初始化 vector<int> a(4); 时,会创建一个包含4个元素的 vector,但在后续的循环中又通过 push_back 方法往 vector 中添加元素,导致实际存储的元素个数为7。这可能会导致输出结果不符合预期,因为排序和输出时会考虑所有7个元素。

修改:

1.把sort的a.end()改为a.begin()+3;

2.不用push_back(),用a[i]读入,并将定义改为vector<int> a(3);

相关推荐
爱喝可乐的老王10 小时前
线性回归模型案例:广告投放效果预测
算法·回归·线性回归
程序员-King.10 小时前
day151—双端队列—找树左下角的值(LeetCode-513)
算法·leetcode·二叉树·双端队列·队列
苦藤新鸡10 小时前
15 .数组右移动k个单位
算法·leetcode·动态规划·力扣
狐5711 小时前
2026-01-19-牛客每日一题-阅读理解
笔记·算法·牛客
橘颂TA11 小时前
【剑斩OFFER】算法的暴力美学——力扣 130 题:被围绕的区域
算法·leetcode·职场和发展·结构与算法
一分之二~11 小时前
回溯算法--解数独
开发语言·数据结构·c++·算法·leetcode
程芯带你刷C语言简单算法题12 小时前
Day48~对于高度为 n 的台阶,从下往上走,每一步的阶数为 1,2,3 中的一个。问要走到顶部一共有多少种走法
c语言·开发语言·学习·算法·c
休息一下接着来12 小时前
C++ 设计模式:Pimpl(Pointer to Implementation)
c++·算法·设计模式
苦藤新鸡12 小时前
18.矩阵同行同列全置零
数据结构·c++·算法·力扣