lightoj 1354 - IP Checking

给定一个十进制的IP地址和一个二进制的IP地址,问两个地址是否是一个。

直接每八位二进制数字转化十进制判断相等,简单模拟

<span style="font-size:14px;">#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define ull unsigned long long
#define mod 1000007
#define inf 0x3f3f3f3f
#define N 100100
char s[100];
int ip[10];
int main()
{
    int t;
    scanf("%d",&t);
    for(int cas=1;cas<=t;cas++)
    {
      int a,b,c,d;
      scanf("%d.%d.%d.%d",&a,&b,&c,&d);
      scanf("%s",s);
      memset(ip,0,sizeof(ip));
      int cnt=0;
      for(int i=0;s[i]!='\0';i++)
      {
          if(s[i]=='.')
            cnt++;
          else
          {
              ip[cnt]=ip[cnt]*2+s[i]-'0';
          }
      }
      if(ip[0]==a&&ip[1]==b&&ip[2]==c&&ip[3]==d)
        printf("Case %d: Yes\n",cas);
      else
        printf("Case %d: No\n",cas);
    }
    return 0;
}
</span>

你可能感兴趣的:(二进制,lightoj)