這個題是2022年9月份c++一級的真題,它說難不難,說不難也難,評判標(biāo)準(zhǔn)主要看學(xué)生學(xué)到哪種程度以及
使用的是哪種方法。
首先來看用最基礎(chǔ)的判斷怎么做:
#include<iostream>
using namespace std;
int main(){
int a,b,c;
cin>>a>>b>>c;
if(a<=b && b<=c &&a<=c){
cout<<a<<" "<<b<<" "<<c;
}
else if(a<=c && a<=b &&c<=b){
cout<<a<<" "<<c<<" "<<b;
}
else if(b<=a && a<=c &&b<=c){
cout<<b<<" "<<a<<" "<<c;
}
else if(b<=c && c<=a &&b<=a){
cout<<b<<" "<<c<<" "<<a;
}
else if(c<=a && c<=b &&a<=b){
cout<<c<<" "<<a<<" "<<b;
}
else if(c<=b && b<=a &&c<=a){
cout<<c<<" "<<b<<" "<<a;
}
return 0;
}
這是用排列組合的方式來做,有的同學(xué)也會直接兩兩個數(shù)進(jìn)行判斷,但那樣實在太麻煩了,需要寫很多層循環(huán)嵌套。
這種題還有另外的出法就是三個數(shù)求最大值,它用的打擂臺的思想,我們也可以使用這種思路來做這個題。
#include<iostream>
using namespace std;
int main(){
int a,b,c,max=0,min=0,m=0;
cin>>a>>b>>c;
max=a;
if(max<b){
max=b;
}
if(max<c){
max=c;
}
min=a;
if(min>b){
min=b;
}
if(min>c){
min=c;
}
m=(a+b+c)-max-min;
cout<<min<<" "<<m<<" "<<max;
return 0;
}
剛剛這兩種做法都是用一級的知識點做的,c++里有一個函數(shù)叫sort,是可以直接對數(shù)據(jù)容器里的數(shù)據(jù)進(jìn)行排序,但這個我們需要借助一維數(shù)組(使用sort必須導(dǎo)入算法庫或者萬能頭)
#include<algorithm>//算法庫
#include<bits/stdc++.h>//萬能頭
using namespace std;
int main(){
int a[3]={0};
scanf("%d%d%d",&a[0],&a[1],&a[2]);
sort(a,a+3);
printf("%d %d %d",a[0],a[1],a[2]);
return 0;
}
還要一種是交換值的方式,這一種就需要先簡單說下它的原理了。
可以先想一下,如果現(xiàn)在有兩瓶顏色不一樣的水,我們怎樣將它們進(jìn)行交換呢?如果直接把一個杯子的水倒進(jìn)另一個杯子,那水直接就會被覆蓋掉。所以我們需要借助一個空杯子,比如A杯子和B杯子裝的是顏色不一樣的水,C杯子是空杯子,那我們只需要先把A杯子里的水倒進(jìn)C杯子,這時A杯子的水空了就可以把B杯子的水倒進(jìn)A杯子,然后再把C杯子裝的A杯子的水再倒進(jìn)B杯子了。(A -->C, B–>A, C–>A)
用編程來寫就是:
int a=5,b=2,c=0;
c=a;
a=b;
b=c;
再回到這個題用這個思路來做的程序就是:文章來源:http://www.zghlxwxcb.cn/news/detail-605803.html
#include<iostream>//算法庫
using namespace std;
int main(){
int a, b, c, t;
scanf("%d %d %d", &a, &b, &c);
if (a < b)
{
t = a;
a = b;
b = t;
}
if (a < c)
{
t = a;
a = c;
c = t;
}
if (b < c)
{
t = b;
b = c;
c = t;
}
printf("%d %d %d", c, b, a);
return 0;
}
好啦,同學(xué)們自己去試一試吧~文章來源地址http://www.zghlxwxcb.cn/news/detail-605803.html
到了這里,關(guān)于c++一級 輸入三個數(shù),按照從小到大的順序輸出的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!