冒泡排序失效?

Dwayne_Wade 2017-12-05 09:16:04
#include<iostream>
#include<vector>
using namespace std;
int main() {
int z;
vector<int> nums1;
while (cin >> z) {
nums1.push_back(z);

}
bool flag;
for (int i = 1; i < nums1.size(); i++) {
flag = false;
for (int j = 0; j<nums1.size() - i; j++) {
if (nums1[j + 1]<nums1[j]) {
int tmp = nums1[j]; nums1[j] = nums1[j + 1]; nums1[j + 1] = tmp; flag = true;
}
if (!flag)break;
}
}
for (int i = 0; i < nums1.size(); i++)cout << nums1[i] << endl;
system("pause");


}
当我输入“ 1 2 3 3 2 1”输出仍为“1 2 3 3 2 1”
...全文
141 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
qq_23302559 2017-12-06
  • 打赏
  • 举报
回复
写成最简单的不就可以了么 for(int i =0;i<size-1;i++) for(int j=0;j<size-1-i;j++) if(a[j]<a[j+1]) {int tem=a[j];a[j]=a[j+1];a[j+1]=tem;}
Sunjihang_123 2017-12-05
  • 打赏
  • 举报
回复
#include<iostream> #include<vector> using namespace std; int main() { int z; vector<int> nums1; while (cin >> z) { nums1.push_back(z); } bool flag = true; for (int i = 1; i < nums1.size() && flag; i++) { flag = false; for (int j = 0; j < nums1.size() - i; j++) { if (nums1[j + 1]>nums1[j]) { int tmp = nums1[j]; nums1[j] = nums1[j + 1]; nums1[j + 1] = tmp; flag = true; } } } for (int i = 0; i < nums1.size(); i++) cout << nums1[i] << endl; system("pause"); return 0; } 标志位设置有问题
真相重于对错 2017-12-05
  • 打赏
  • 举报
回复
算法不对!!!!

65,186

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧