天天看點

金山雲-9.23 C++背景開發筆試

  • 按照從上到下,從左往右順序輸入一顆二叉樹中每一個結點對應的權重,判斷該滿二叉樹是否存在這樣的非葉子節點,使得左數所有葉子結點之和等于右樹所有葉子結點之和,如果存在輸出Yes,不存在輸出No。
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
#include <numeric>
#include <sstream>
using namespace std;

int sum(vector<int>v, int index)
{
    if (index<v.size())
        return v[index] + sum(v, 2 * index + 1) + sum(v, 2 * index + 2);
    else return 0;
}
int main()
{
    //input  demo
    vector<vector<int>> v;
    int count;
    cin >> count;
    getchar();
    for (int i = 0; i < count; i++)
    {
        vector<int> temp;
        string str;
        getline(cin, str);
        stringstream ss;
        ss << str;
        string number;
        while (getline(ss, number, ' '))
        {
            temp.push_back(stoi(number));
        }
        v.push_back(temp);
    }
    //
    for (int k = 0; k < v.size(); k++)
    {
        int flag = 0;
        for (int i = 0; i <= (v[k].size() / 2 - 1); i++)
        {
            if (sum(v[k], 2 * i + 1) == sum(v[k], 2 * i + 2))
            {
                cout << "Yes" << endl;
                flag = 1;
                break;
            }
        }
        if (flag == 0) cout << "No" << endl;
    }
}
           
  • 輸入正整數n,判斷1-n之間整數出現5的次數(暴力解法)
#include <iostream>
using namespace std;

int findFive(int n){
    int res = 0;
    for (int i = 1; i <= n; i++) {
        int temp = i;
        while (temp > 0) {
            if (temp % 10 == 5) {
                res++;
            }
            temp = temp / 10;
        }
    }
    return res;
}

int main() {
    int n;
    cin >> n;
    cout << findFive(n) << endl;
    return 0;
}           

繼續閱讀