招商银行信用卡中心2019秋招IT笔试(开发方向第二批)

题目名称:
X游戏
题目描述:
我们称一个数 X 为好数, 如果它的每位数字逐个地被旋转 180 度后,我们仍可以得到一个有效的,且和 X 不同的数。要求每位数字都要被旋转。
如果一个数的每位数字被旋转以后仍然还是一个数字, 则这个数是有效的。0, 1, 和 8 被旋转后仍然是它们自己;2 和 5 可以互相旋转成对方;6 和 9 同理,除了这些以外其他的数字旋转以后都不再是有效的数字。
现在我们有一个正整数 N, 计算从 1 到 N 中有多少个数 X 是好数?
输入描述:
输入正整数N
输出描述:
输出1到N中好数个数
输入:
10
输出:
4
题意:
题目描述
题解
满足的字符串必须不包含347;并且包含2569
代码:

#include
#include
#include
#include
using namespace std;
 
bool IsValid(int n){
    int cnt = 0;
    while(n){
        int t = n % 10;
        n /= 10;
        if(t == 2 || t == 5 || t == 6 || t == 9) cnt ++;
        if(t == 3 || t == 4|| t == 7) return false;
    }
    if(cnt > 0)
        return true;
    else return false;
}
 
int main(){
    int n;
    while(scanf("%d",&n)!=EOF){
        int ans = 0;
        for(int i = 1; i <= n; i ++){
            if(IsValid(i)) ans ++;
        }
        printf("%d\n",ans);
    }
    return 0;
}

题目名称:
跳格子游戏
题目描述:
假设你正在玩跳格子(所有格子排成一个纵列)游戏。需要 跳完n 个格子你才能抵达终点。
每次你可以跳 1 或 2 个格子。你有多少种不同的方法可以到达终点呢?
注意:给定 n 是一个正整数。
输入描述:
格子数n
输出描述:
跳完n个格子到达终点的方法
输入:
2
输出:
2
题意:
题目描述
题解
斐波拉契数列
代码:

#include
#include
#include
#include
using namespace std;
 
typedef long long ll;
const int maxn = 50 + 5;
int f[maxn];
 
void init(){
    f[1] = 1;
    f[2] = 2;
    for(int i = 3; i <= 50; i ++){
        f[i] = f[i - 1] + f[i - 2];
    }
}
 
int main(){
    int n;
    init();
    while(scanf("%d",&n)!=EOF){
        printf("%lld\n",f[n]);
    }
    return 0;
}

题目名称:
糖果分配
题目描述:
假设你是一位很有爱的幼儿园老师,想要给幼儿园的小朋友们一些小糖果。但是,每个孩子最多只能给一块糖果。对每个孩子 i ,都有一个胃口值 gi ,这是能让孩子们满足胃口的糖果的最小尺寸;并且每块糖果 j ,都有一个尺寸 sj 。如果 sj >= gi ,我们可以将这个糖果 j 分配给孩子 i ,这个孩子会得到满足。你的目标是尽可能满足越多数量的孩子,并输出这个最大数值。
注意:
你可以假设胃口值为正。
一个小朋友最多只能拥有一块糖果。
输入描述:
格子数n
输出描述:
跳完n个格子到达终点的方法
输入:
2
输出:
2
题意:
题目描述
题解
简单贪心
代码:

#include
#include
#include
#include
#include
using namespace std;
int main(){
    int num;
    vector<int> g;
    vector<int> s;
    while(cin>>num){
        g.push_back(num);
        if(getchar() == '\n')
            break;
    }
    while(cin>>num){
        s.push_back(num);
        if(getchar() == '\n')
            break;
    }
    sort(g.begin(),g.end());
    sort(s.begin(),s.end());
    int sum = 0;
    for(int i = 0,j = 0;j < s.size(); j ++){
        if(i >= g.size())
            break;
        if(s[j] >= g[i]){
            sum ++;
            i ++;
        }
    }
    cout<<sum<<endl;
    return 0;
}

你可能感兴趣的:(算法,面试)