[PAT解题报告] 锤子剪刀布 (20)

转载 from http://tech-wonderland.net/blog/pat-basic-level-practice-1016-1020-solutions.html

解题思路: 直接模拟解决, 可能是想考察编程的基本功吧. 按照字典序, B-C-j来做的话, 代码可以更加精简一点. 下面是可以AC的代码:

#include <iostream>
#include <algorithm>

int comp(char a, char b) {
    if(a == b) return 0;
    if( ('C' == a && 'J' == b) ||
        ('J' == a && 'B' == b) ||
        ('B' == a && 'C' == b)
        )
        return 1;
    return -1;
}

int mapping(char c) {
    if('B' == c) return 0;
    if('C' == c) return 1;
    return 2; // 'J'
}

char maxChar(int chArray[3]) {
    int maxV = *std::max_element(chArray, chArray + 3);
    if(chArray[0] == maxV)
        return 'B';
    if(chArray[1] == maxV)
        return 'C';
    return 'J';
}

int main() {
    int n;
    std::cin >> n;
    char a, b;
    int iCountWin = 0;
    int iCoundEven = 0;
    int cnt1[3] = {0, 0, 0};
    int cnt2[3] = {0, 0, 0};

    for(int i = 0; i < n; ++i) {
        std::cin >> a >> b;
        int ret = comp(a, b);
        if(1 == ret) {
            ++iCountWin;
            ++cnt1[mapping(a)];
        }
        else if(0 == ret)
            ++iCoundEven;
        else {
            ++cnt2[mapping(b)];
        }
    }
    std::cout << iCountWin << ' ' << iCoundEven << ' ' << n - iCoundEven - iCountWin << std::endl;
    std::cout << n - iCoundEven - iCountWin << ' ' << iCoundEven << ' ' << iCountWin << std::endl;
    std::cout << maxChar(cnt1) << ' ' << maxChar(cnt2) << std::endl;
    return 0;
}

全部评论
小小老师好,我有个问题请教您。 我定义了一个字符数组 char jia[110], yi[110]; 然后输入 for(i=0;i<N;i++) { scanf("%c %c", &jia[i], &yi[i]); } 在程序运行中出现这样的问题: 无法输入N行数据,只能输入N/2行左右的数据,就输出了。 尝试了一下,当改为scanf("%s %s", &jia[i], &yi[i]);就正常输入输出了。 请问这是为什么呢?为什么往字符数组中输入字符,不能用%c,而只能用%s呢?
点赞 回复 分享
发布于 2016-12-08 22:59

相关推荐

不愿透露姓名的神秘牛友
今天 10:52
点赞 评论 收藏
分享
hso_:哈哈哈哈哈哈我没offer一样在同一道题开喷了
投递深圳同为数码等公司10个岗位
点赞 评论 收藏
分享
10-07 23:57
已编辑
电子科技大学 Java
八街九陌:博士?客户端?开发?啊?
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务