编写一个程序,用户输入若干整数,试找出其中的最大数和最小数。
【输入形式】
用户在第一行待输入数据个数,在第二行输入数据。
【输出形式】
程序在下一行输出数据的最大值和最小值
【样例输入】
5
89 62 96 74 52
【样例输出】
96 52
【样例说明】
用户第一次输入的为数据个数,在下一行依次输入数据。输出为5个数中的最大值和最 小值,输出时候两个数之间用一个空格分隔。
方法一.
题目条件要求为从输入的若干个整数中寻找最大和最小值,那么最容易想到的就是循环输入n次,并且将每一位数进行比较得出最大和最小。但是,有个问题就是我们无法将输入的数逐个的进行直接比较。那么我们就需要引入一个特别大的最小值和特别小的最大值(使得每个数与其二比较替换)最后按照格式输入即可。代码如下,仅供参考,欢迎指出问题。
#include<iostream>
using namespace std;
int main(){
int n,a;
int min=999999;
int max=-999999;
cin>>n;
for(int i=0;i<=n;i++){
cin>>a;
if(a>max){
max=a;
}
if(a<min){
min=a;
}
}
cout<<max<<" "<<min;
return 0;
}
方法二.数组
回顾题目,如果学过数组的话,脑海里应该最先想到用数组的方法来解题。对于我最开始也是想到数组奈何刚学习还不知道动态数组如何使用,就无功而返。在看到书之后,学到了动态分配数组的new方法就得到了下面的代码。注意:new需要和delete连用
#include <iostream>
using namespace std;
int main() {
int n,i;
int max;
int min;
cin>>n;
int *p=new int[n];
for (i=0;i<n;i++)
cin>>p[i];
max=min=p[0];
for (i = 1; i < n; i++)
{
if (p[i] > max)
max = p[i];
if (p[i] < min)
min = p[i];
}delete[]p;
cout<<max<<" "<<min;
return 0;
}
THE END
喜欢就支持一下吧