[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

相关推荐

大清早迷迷糊糊被闹钟叫醒,坐在电脑面前开始答题,硬生生坐了2小时,要是不进面,我都无颜面对我的屁股
在看数据的傻狍子很忙碌:26届还好啦。我昨晚还要跟mt值班降级熔断的测试 , 回来做一下上周的美团笔试 , 做完已经快三点了。只a出1.25。而且手机还断网了4次五六秒,已经心碎了。
投递美团等公司10个岗位 > 美团求职进展汇总
点赞 评论 收藏
分享
程序员小白条:找实习多投就行,但25届现在是春招时间呃呃呃,你想以后参加社招吗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务