1. 程式人生 > >首屆CCF計算機職業資格認證考試題解(C++)

首屆CCF計算機職業資格認證考試題解(C++)

試題名稱: 出現次數最多的數

試題編號:201312-1
時間限制: 1.0s
記憶體限制: 256.0MB

問題描述

  給定n個正整數,找出它們中出現次數最多的數。如果這樣的數有多個,請輸出其中最小的一個。

輸入格式

  輸入的第一行只有一個正整數n(1 ≤ n ≤ 1000),表示數字的個數。
  輸入的第二行有n個整數s1, s2, …, sn (1 ≤ si ≤ 10000, 1 ≤ i ≤ n)。相鄰的數用空格分隔。

輸出格式

  輸出這n個次數中出現次數最多的數。如果這樣的數有多個,輸出其中最小的一個。

樣例輸入

6
10 1 10 20 30 20

樣例輸出

10

第一題挺水的,資料範圍才10000,開個陣列就好了,分別記錄數字出現的次數。最後遍歷一次,從前往後找,反正題目要求,如果這樣的數有多個,請輸出其中最小的一個

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;

int num[10005];

int main()
{
    int n, a;
    memset(num, 0, sizeof(num));
    scanf("%d", &n);
    for(int
i = 0; i < n; i++){ scanf("%d", &a); num[a]++; } int inum, imax; inum = imax = 0; for(int i = 1; i < 10005; i++){ if(imax < num[i]){ imax = num[i]; inum = i; } } printf("%d\n", inum); return 0; }

試題名稱: ISBN號碼

試題編號: 201312-2
時間限制: 1.0s
記憶體限制: 256.0MB

問題描述

  每一本正式出版的圖書都有一個ISBN號碼與之對應,ISBN碼包括9位數字、1位識別碼和3位分隔符,其規定格式如“x-xxx-xxxxx-x”,其中符號“-”是分隔符(鍵盤上的減號),最後一位是識別碼,例如0-670-82162-4就是一個標準的ISBN碼。ISBN碼的首位數字表示書籍的出版語言,例如0代表英語;第一個分隔符“-”之後的三位數字代表出版社,例如670代表維京出版社;第二個分隔之後的五位數字代表該書在出版社的編號;最後一位為識別碼。
  識別碼的計算方法如下:
  首位數字乘以1加上次位數字乘以2……以此類推,用所得的結果mod 11,所得的餘數即為識別碼,如果餘數為10,則識別碼為大寫字母X。例如ISBN號碼0-670-82162-4中的識別碼4是這樣得到的:對067082162這9個數字,從左至右,分別乘以1,2,…,9,再求和,即0×1+6×2+……+2×9=158,然後取158 mod 11的結果4作為識別碼。
  編寫程式判斷輸入的ISBN號碼中識別碼是否正確,如果正確,則僅輸出“Right”;如果錯誤,則輸出是正確的ISBN號碼。

輸入格式

  輸入只有一行,是一個字元序列,表示一本書的ISBN號碼(保證輸入符合ISBN號碼的格式要求)。

輸出格式

  輸出一行,假如輸入的ISBN號碼的識別碼正確,那麼輸出“Right”,否則,按照規定的格式,輸出正確的ISBN號碼(包括分隔符“-”)。

樣例輸入

0-670-82162-4

樣例輸出

Right

樣例輸入

0-670-82162-0

樣例輸出

0-670-82162-4

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;

int main()
{
    char isbn[20], b;
    int sum = 0, num;
    memset(isbn, '\0', sizeof(isbn));
    scanf("%s", isbn);
    num = isbn[12]-'0';
    for(int i = 0, j = 1; i < 11; i++){
        if('-' == isbn[i])
            continue;
        sum = sum+j*(isbn[i]-'0');
        j++;
    }

    sum%=11;

    if(10 == sum)
        b = 'X';
    else
        b = '0'+sum;

    if(isbn[12] == b)
        printf("Right\n");
    else{
        for(int i = 0; i < 12; i++)
            printf("%c", isbn[i]);
        printf("%c\n", b);
    }
    return 0;
}

試題名稱: 最大的矩形

試題編號: 201312-3
時間限制: 1.0s
記憶體限制: 256.0MB

問題描述

  在橫軸上放了n個相鄰的矩形,每個矩形的寬度是1,而第i(1 ≤ i ≤ n)個矩形的高度是hi。這n個矩形構成了一個直方圖。例如,下圖中六個矩形的高度就分別是3, 1, 6, 5, 2, 3。

這裡寫圖片描述

  請找出能放在給定直方圖裡面積最大的矩形,它的邊要與座標軸平行。對於上面給出的例子,最大矩形如下圖所示的陰影部分,面積是10。

這裡寫圖片描述

輸入格式

  第一行包含一個整數n,即矩形的數量(1 ≤ n ≤ 1000)。
  第二行包含n 個整數h1, h2, … , hn,相鄰的數之間由空格分隔。(1 ≤ hi ≤ 10000)。hi是第i個矩形的高度。

輸出格式

  輸出一行,包含一個整數,即給定直方圖內的最大矩形的面積。

樣例輸入

6
3 1 6 5 2 3

樣例輸出

10

最笨的方法,暴力!

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;

int main()
{
    int n;
    int h[1010];
    while(scanf("%d", &n)!=EOF){
        for(int i = 0; i < n; i++)
            scanf("%d", &h[i]);

        int maxn = 0, hmin = 0;
        for(int i = 0; i < n; i++){
            hmin = h[i];
            for(int j = i; j < n; j++){
                if(hmin > h[j])
                    hmin = h[j];
                int a;
                a = (j-i+1)*hmin;
                if(a > maxn)
                    maxn = a;
            }
        }
        printf("%d\n", maxn);
    }
    return 0;
}