题解 | #判断两个IP是否属于同一子网#

判断两个IP是否属于同一子网

https://www.nowcoder.com/practice/34a597ee15eb4fa2b956f4c595f03218

#include <stdio.h>

int main() {
    int dns[4]={0}, ip1[4]={0}, ip2[4]={0};
    scanf("%d.%d.%d.%d\n",&dns[0],&dns[1],&dns[2],&dns[3]);
    scanf("%d.%d.%d.%d\n",&ip1[0],&ip1[1],&ip1[2],&ip1[3]);
    scanf("%d.%d.%d.%d\n",&ip2[0],&ip2[1],&ip2[2],&ip2[3]);
    /* 格式判斷 */
    int i, flag=0;
    for (i=0; i<4; i++) {
        if (dns[i]>255 || dns[i]<0 || ip1[i]>255 || ip1[i]<0 || ip2[i]>255 || ip2[i]<0) {
            flag=1;
            printf("%d\n",flag);
            return 0;
        }
    }
    for (i=0; i<4; i++) {
        // printf("dns[%d]=%d\n",i,dns[i]);
        if (dns[i]!=255 && dns[i]!=0xfe && dns[i]!=0xfc && dns[i]!=0xf8 && dns[i]!=0xf0 && dns[i]!=0xe0 && dns[i]!=0xc0 && dns[i]!=0x80 && dns[i]!=0) {
            flag=1;
            printf("%d\n",flag);
            return 0;
        } else {
            if ((i==0&&dns[i]==0)||(i==3&&dns[i]==255)) {
                flag =1;  
                printf("%d\n",flag); 
                return 0;
            } else {
                if (i>0&&dns[i-1]<255 &&dns[i]!=0) {
                    flag=1;
                    printf("%d\n",flag);
                    return 0;
                }
            }
        }
    }
    /* 同子網判斷 */
    for (i=0; i<4; i++) {
        if ((dns[i]&ip1[i])!=(dns[i]&ip2[i])) {
            flag=2; 
            printf("%d\n",flag); 
            return 0;
        }
    }
    printf("%d\n", flag);
    return 0;
}

全部评论

相关推荐

07-01 17:14
中北大学 Java
兄弟们是真是假
牛客46374834...:我在boss上投java岗从来没成功过
点赞 评论 收藏
分享
湫湫湫不会java:先投着吧,大概率找不到实习,没实习的时候再加个项目,然后把个人评价和荣誉奖项删了,赶紧成为八股战神吧,没实习没学历,秋招机会估计不多,把握机会。或者说秋招时间去冲实习,春招冲offer,但是压力会比较大
点赞 评论 收藏
分享
07-01 13:37
门头沟学院 Java
steelhead:不是你的问题,这是社会的问题。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务