题解 | #密码验证合格程序#

素数伴侣

http://www.nowcoder.com/practice/b9eae162e02f4f928eac37d7699b352e

#include <stdio.h>
#include <string.h>
#include <stdbool.h>

#define MAX(a, b) ((a > b) ? (a) : (b))
static unsigned short g_int[100]; /* 输入的原始全部数据,并按先奇数,再偶数的顺序排列 */
static int g_num[2]; /* 1 表示输入数据的总数量,0表示奇数的总数量 */
static char g_status[100]; /* 偶数是否匹配过,且保持匹配过的奇数下标索引值,该数值初始化为 101 */
static bool g_curFlag[100]; /* 当前轮的是否匹配过的标记 */
static bool match(int odd)
{
    for (int j = g_num[0]; j < g_num[1]; j++) { /* 偶数范围 */
        if (g_curFlag[j] == true) continue;
        int k = 2, data = g_int[odd] + g_int[j];
        for (; k * k <= data;  k++) if (data % k == 0) break;
        if (k * k <= data) continue;

        g_curFlag[j] = true;
        if ((g_status[j] == 101) || match(g_status[j])) {
            g_status[j] = odd;
            return true;
        }
    }

    return false;
}

int main(int argc, char** argv)
{
    int acount = 0;
    scanf("%d", &g_num[1]);
    for (int i = 0; i < g_num[1]; i++) scanf("%hd", g_int + i);

    g_num[0] = g_num[1]; /* 假定所有数为奇数,遍历全表,如果有偶数,则移动到后面 */
    while ((g_num[0] > 0) && (g_int[g_num[0] - 1] % 2 == 0)) g_num[0]--;
    for (int i = 0; i < g_num[0]; i++) {
        if (g_int[i] % 2 != 0) continue;
        while ((g_num[0] - 1 > i) && (g_int[g_num[0] - 1] % 2 == 0)) g_num[0]--;
        if (g_num[0] - 1 > i) {
            g_int[i] ^= g_int[g_num[0] - 1] ^= g_int[i] ^= g_int[g_num[0] - 1]; g_num[0]--;
        }
        while ((g_num[0] - 1 > i) && (g_int[g_num[0] - 1] % 2 == 0)) g_num[0]--;
    }

    memset(g_status, 101, sizeof(g_status));
    for (int i = 0; i < g_num[0]; i++) { /* 奇数范围 */
        memset(g_curFlag, 0, sizeof(g_curFlag));
        if (match(i)) acount++;
    }
    printf("%d\n", acount);
    return 0;
}

全部评论

相关推荐

点赞 评论 收藏
分享
10-11 17:30
湖南大学 C++
我已成为0offer的糕手:羡慕
点赞 评论 收藏
分享
评论
点赞
收藏
分享
正在热议
# 25届秋招总结 #
443331次浏览 4520人参与
# 春招别灰心,我们一人来一句鼓励 #
42187次浏览 537人参与
# 北方华创开奖 #
107472次浏览 600人参与
# 地方国企笔面经互助 #
7973次浏览 18人参与
# 同bg的你秋招战况如何? #
77166次浏览 569人参与
# 实习必须要去大厂吗? #
55811次浏览 961人参与
# 阿里云管培生offer #
120447次浏览 2220人参与
# 虾皮求职进展汇总 #
116310次浏览 887人参与
# 如果你有一天可以担任公司的CEO,你会做哪三件事? #
11683次浏览 289人参与
# 实习,投递多份简历没人回复怎么办 #
2454962次浏览 34861人参与
# 提前批简历挂麻了怎么办 #
149927次浏览 1978人参与
# 在找工作求抱抱 #
906124次浏览 9423人参与
# 如果公司给你放一天假,你会怎么度过? #
4762次浏览 55人参与
# 你投递的公司有几家约面了? #
33209次浏览 188人参与
# 投递实习岗位前的准备 #
1196037次浏览 18550人参与
# 机械人春招想让哪家公司来捞你? #
157648次浏览 2267人参与
# 双非本科求职如何逆袭 #
662384次浏览 7397人参与
# 发工资后,你做的第一件事是什么 #
12806次浏览 62人参与
# 工作中,努力重要还是选择重要? #
35906次浏览 384人参与
# 简历中的项目经历要怎么写? #
86937次浏览 1516人参与
# 参加完秋招的机械人,还参加春招吗? #
20153次浏览 240人参与
# 我的上岸简历长这样 #
452074次浏览 8089人参与
牛客网
牛客企业服务