解题思路:
  先去重,后排序,再输出。






注意事项:





参考代码:

#include<iostream>

using namespace std;

int main()

{

   int n[100];

   int m;

   cin >> m;

   for (int i = 0;i < m;i++)                //输入m个数

      cin >> n[i];

   for (int i = 0;i < m - 1;i++)             //去重开始

   {

      for (int j = i + 1;j < m;j++)         

     {

         if (n[i] == n[j])              //如果相同

         {

           for (int k = i;k < m - 1;k++)    //从相同的那个数后一个数开始,向前移一位。

              n[k] = n[k + 1];

           m--;                    //m减一

           i--;                    //i减一,使得下次比较是从想同的位置开始

         }

     }

    }                             //去重结束

   for (int i = 0;i < m;i++)             //排序开始

   {

      for (int j = i + 1;j < m;j++)       //如果前一个比后一个数大,让他俩相互换位

      {

         if (n[i] > n[j])

         {

            int a = n[i];

            n[i] = n[j];

            n[j] = a;

          }

      }

    }                          //排序结束

   cout << m << endl;               //输出不相同的数字的个数

   for (int i = 0;i < m;i++)          //输出排序好的数

   {

      if (i != 0)

        cout << " ";

      cout << n[i];

   }

   cout << endl;

   return 0;

}


点赞(8)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论