我的排序怎么最小的一个数怎么数不出来!~~大家帮帮忙~

zeroman20 2004-03-27 09:09:36
#include <iostream.h>
void chu();
void ru();
void suan();

int num[10];
void main()
{
ru();
suan();
chu();
}
void ru()
{
int i=0;
do{
cout<<"please input No."<<(i++)+1<<" number"<<endl;
cin>>num[i];
}while(i<10);
}
void suan()
{
for(int i=0;i<10;i++)
{
for(int j=i+1;j<10;j++)
{
if(num[i]>num[j])
{
int temp=num[j];
num[j]=num[i];
num[i]=temp;
}
}
}
}
void chu()
{
int j=0;
for(;j<10;j++)
{
cout<<"Output No."<<j+1<<" number is:";
cout<<num[j]<<endl;
}
}


...全文
95 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
sgboy 2004-03-28
  • 打赏
  • 举报
回复
sorry,应该是
for(i=0;i<10 ;i++)
{
cout<<"please input No."<<i+1<<" number"<<endl;
cin>>num[i];//////////////
}
sgboy 2004-03-28
  • 打赏
  • 举报
回复
可以改为for(i=0;i<10 ;i++)
{
cout<<"please input No."<<i+1<<" number"<<endl;
cin>>num[i++];
}
sgboy 2004-03-28
  • 打赏
  • 举报
回复
do{
cout<<"please input No."<<(i++)+1<<" number"<<endl;
cin>>num[i];
}while(i<10);
输入的数存储在num[1] --- num[10],而num[10]的范围是num[0]-num[9],这样越界了。输入的第一个数字存在第二个位置,第一个位置num[0]仍然是默认的0。
shafish 2004-03-28
  • 打赏
  • 举报
回复
#include <iostream>
using namespace std;

static void chu();
static void ru();
static void suan();

static int num[10];
int main()
{
ru();
suan();
chu();
system("pause");
return 0;
}

void ru()
{
int i=0;
do{
cout<<"please input No."<<i+1<<" number"<<endl;
cin>>num[i];
}while(++i<10);
}
void suan()
{
for(int i=0; i<9; i++)
{
for(int j=i+1; j<10; j++)
{
if(num[i]>num[j])
{
int temp=num[j];
num[j]=num[i];
num[i]=temp;
}
}
}
}
void chu()
{
int j=0;
for(;j<10;j++)
{
cout<<"Output No."<<j+1<<" number is:";
cout<<num[j]<<endl;
}
}


dev-c++ 调试通过
zhangfjj 2004-03-27
  • 打赏
  • 举报
回复
void ru()
{
int i=0;
do{
cout<<"please input No."<<i+1<<" number"<<endl;
cin>>num[i];
i++;
//或者合成一个语句cin>>num[i++];
}while(i<10);
}
zeroman20 2004-03-27
  • 打赏
  • 举报
回复
哦 我本想输出第几个数, 可是这样也能修改变量啊
paddy102 2004-03-27
  • 打赏
  • 举报
回复
void ru()
{
int i=0;
do{
cout<<"please input No."<<(i++)+1<<" number"<<endl;
cin>>num[i];
}while(i<10);
}

Error1: 输入的数存储在num[1] --- num[10](我想你原来的目的应该不是这样的);
Warning1: Suan()函数中的
for(int i=0;i<10;i++) // i<9就行了,因为i=9时,j=10
{
for(int j=i+1;j<10;j++)
{ ...}
内容概要:本文系统梳理了多个科研领域的前沿研究与技术实现,重点涵盖FDTD方法中的完美匹配层(PML)研究,以及Matlab/Simulink在电磁、电力、控制、通信、信号处理、图像处理、路径规划、能源系统优化等领域的仿真与算法实现。文中列举了大量基于Matlab和Python的科研案例,如风电功率预测、负荷预测、无人机三维路径规划、电池系统故障诊断、雷达模拟、通信编码、微电网优化调度等,并强调结合智能优化算法(如粒子群、遗传算法、深度学习等)提升系统性能。同时,提供了丰富的代码资源与仿真模型,涵盖永磁同步电机控制、逆变器设计、多智能体任务分配、虚拟电厂调度等复杂系统,助力科研人员快速开展复现实验与创新研究。; 适合人群:具备一定编程基础,熟悉Matlab/Python工具,从事电气工程、自动化、通信、人工智能、新能源、控制科学等相关领域研究的研发人员及研究生。; 使用场景及目标:① 学习并实现FDTD仿真中的PML边界条件以有效抑制值反射;② 掌握Matlab/Simulink在多物理场建模、控制系统设计与优化算法中的综合应用;③ 借助提供的代码资源完成科研复现、课程设计、竞赛项目或工程原型开发; 阅读建议:此资源以科研实战为导向,不仅提供理论方法,更强调代码实现与仿真验证。建议读者结合自身研究方向,按目录顺序查阅相关模块,下载配套代码进行调试与二次开发,以达到学以致用、融会贯通的目的。

65,211

社区成员

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

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