C小加 之 隨機數

來源:互聯網
上載者:User

標籤:style   color   資料   io   for   art   問題   代碼   

C小加 之 隨機數

時間限制:3000 ms  |  記憶體限制:65535 KB

難度:1

描寫敘述

ACM隊的“C小加”同學想在學校中請一些同學一起做一項問卷調查,為了實驗的客觀性,他先用電腦產生了N個1到1000之間的隨機整數(0<N≤100),對於當中反覆的數字,僅僅保留一個,把其餘同樣的數去掉,不同的數相應著不同的學生的學號。然後再把這些數從小到大排序,依照排好的順序去找同學做調查。請你協助 C小加 完畢“去重”與“排序”的工作。

輸入

第一行輸入整數T(1<T<10)表示多少組測試資料,
每組測試資料包含2行,
第1行為1個正整數,表示所產生的隨機數的個數:N(0<N≤100)
第2行有N個用空格隔開的正整數,為所產生的隨機數。
(隨機數為題目給定的,不須要ACMer產生)

輸出

輸出也是2行,第1行為1個正整數M,表示不同樣的隨機數的個數。
第2行為M個用空格隔開的正整數,為從小到大排好序的不同樣的隨機數。

例子輸入

11020 40 32 67 40 20 89 300 400 15

例子輸出

815 20 32 40 67 89 300 400

 

題解:

   (1)遇到“去重”與“排序”的問題,記住要先排序,由於排完序之後,反覆的肯定在一起,僅僅需a[i]!=a[i-1],把a[i]輸出就可以。

   (2)排序能夠用qsort,也可用冒泡排序。

對int類型數組排序

int num[100];

int cmp ( const void *a , const void *b )
{
return *(int *)a - *(int *)b;//由小到大排序,return *(int *)b-*(int *)a; 為由大到小排序。 
}

qsort(num,100,sizeof(num[0]),cmp);

 

程式碼:

#include<stdio.h>

#include<stdlib.h>

 

int cmp(const void *a,const void *b)

{

     return *(int *)a-*(int *)b;

}

 

int main()

{

  int t,n,i,j,count;

  int a[1010];

  scanf("%d",&t);

  while(t--)

  {

    scanf("%d",&n);

    for(i=0;i<n;i++)

    scanf("%d",a+i);

    qsort(a,n,sizeof(a[0]),cmp);

    for(count=i=0;i<n;i++)

    {

       if(a[i]==a[i+1])

       {

         count++;

         continue;

       }

    }

    printf("%d\n",n-count);

    for(i=0;i<n;i++)

      if(a[i]!=a[i-1])

        printf("%d ",a[i]);

      putchar(‘\n‘);

  }

     system("pause");

     return 0;

            

                                                  

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.