编程实现如下功能:
1.输入100个以内的整数,以逗号离开;
2.将这些整数从大到小输出,中间以逗号隔开;
3.输出的数据中若含有三个以上的连续整数,则只输出连续列的最大值和最小值;
4.不考虑输入数字重复的情况。
例如:输入:1,2,3,4,7,8,9 输出:9,7,4,1
#include<iostream>
#include<stdio.h>
#include<algorithm>
using namespace std;
void sort2(int a[],int m);
int main()
{
int i=0,j=0,m=0;
char ch=',';
int a[100];
while(ch!='\n'&& m<100 )
{
scanf("%d%c",&a[i++],&ch);//一定要记得加取地址符&
m++;
}
sort(a,a+m,greater<int>());
int k=1;
printf("%d%c",a[0],',');
while(k<m-1) //最后一个元素不比较,直接输出
{
if((a[k-1]!=a[k]+1)||(a[k]!=a[k+1]+1))
printf("%d%c",a[k],',');
k++;
}
printf("%d",a[m-1]);
}
void sort2(int a[],int m)
{
for(int i=0;i<m-1;i++)
for(int j=0;j<m-1-i;j++)
if(a[j]<a[j+1])
{
int tmp=a[j];
a[j]=a[j+1];
a[j+1]=tmp;
}
}