文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

通过C语言判断字符串是否为点分十进制的IP地址

2023-03-20 11:59

关注

判断字符串是否为点分十进制的IP地址

判断字符串是否为点分十进制的IP地址。

若是则转为16进制,

否则输出"error"。

例如

注意:

Internet委员会定义了5种IP地址类型以适合不同容量的网络,即A类~E类。IP地址通常用“点分十进制”表示成**(a.b.c.d)的形式**,其中,a,b,c,d都是0-255之间的十进制整数。实际上是32位二进制(01100100.00000100.00000101.00000110)

完整代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define maxsize 100
//十进制转为十六进制
int dtox(int n,char st[]){
	int m;
	int top=-1;
	char c[]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
	while(n){
		m=n%16;
		st[++top]=c[m];
		n=n/16;
	}
	return top;
}
//输出十进制转为十六进制的结果
void out(char st[],int top){
	while(top>-1){
		printf("%c",st[top--]);
	}
}
//将十进制的192字符串转为int类型的192
int stringtoint(char s[]){
	int sum=0;
	int count=1;
	for(int i=strlen(s)-1;i>=0;i--){
		sum+=(s[i]-'0')*count;
		count=count*10;		
	}
	return sum;
}
//将字符串用.分开
int split(char s[],int t[])
{	char tmp[maxsize];
	memset(tmp, 0, sizeof(tmp));
	int count,c;
	int n1=0;
	int i=0;
	int n;
	c=0;
	while(i<strlen(s)){
		count=0;
		while(s[i]!='\0'&&s[i]!='.'){
			if(s[i]>='0'&&s[i]<='9'){
				tmp[count++]=s[i++];
			}
			else return -1;
		}
		n=stringtoint(tmp);
		if(n>255 or n<0) return -1;

		t[n1++]=n;
		memset(tmp, 0, sizeof(tmp));
		i++; 
	}
	return n1;
}
//判断是否是正确的十进制ip地址
void panduan(){
	char s[maxsize];
	scanf("%s",s);
//	char s[]="192.41.6.20";
//	char s[]="abc.41.6.20";
//  192.41.6.20.22
	int t[maxsize];
	int n1;
	n1=split(s,t);
	if(n1>4||n1==-1){
		printf("error"); 
		return ;
	} 
	for(int i=0;i<n1;i++){
		if(i==0)	printf("%#02X",t[i]); 
		else printf("%02X",t[i]);
	}
}
int main(){
	panduan();
//验证十六进制转为十进制的函数 
//	int n;
//	scanf("%d",&n);
//	char st[maxsize];
//	int top;
//	top=dtox(n,st);
//	out(st,top);
//验证十进制的字符串转为十进制数int类型 
//	char s[]="192";
//	printf("\n%d ",	stringtoint(s));
// "192.41.6.20"转为十六进制0XC0290614 
	
}

易错点:16进制格式化输出

printf("%#02X",t[i]);

会加入前缀0X,如果2位缺的话用0填充

如6转为0X06

20转为0X14

printf("%x\n", 47);  //输出结果为:    2f
printf("%X\n", 47);  //输出结果为:    2F
printf("%#x\n", 47); //输出结果为:    0x2f
printf("%#X\n",47); //输出结果为:    0X2F    %#X推荐使用
#include <stdio.h>
int main(){
    int a = 120;
	
    printf("%d\n",a);
    
    printf("%4d\n",a);
    
    printf("%04d\n",a);

	    
    printf("%x\n",a);
     
    printf("%4x\n",a);
    
    printf("%04x\n",a);

    return 0;
}

自己写函数,将输入的十进制转为十六进制并且输出

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define maxsize 100
//十进制转为十六进制
int dtox(int n,char st[]){
	int m;
	int top=-1;
	char c[]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
	while(n){
		m=n%16;
		st[++top]=c[m];
		n=n/16;
	}
	return top;
}
//输出十进制转为十六进制的结果
void out(char st[],int top){
	while(top>-1){
		printf("%c",st[top--]);
	}
}
int main(){
//验证十六进制转为十进制的函数 
	int n;
	scanf("%d",&n);
	char st[maxsize];
	int top;
	top=dtox(n,st);
	out(st,top);
}

函数:将表示一个十进制的字符串转为数字类型

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define maxsize 100
int stringtoint(char s[]){
	int sum=0;
	int count=1;
	for(int i=strlen(s)-1;i>=0;i--){
		sum+=(s[i]-'0')*count;
		count=count*10;		
	}
	return sum;
}
int main(){
	char s[]="192";
	printf("\n%d ",	stringtoint(s));
	}

函数:将字符串用句号分裂开

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define maxsize 100
void split(char s[])
{	char tmp[maxsize];
	memset(tmp, 0, sizeof(tmp));
	int count,c;
	int i=0;
	c=0;
	while(i<strlen(s)){
		count=0;
		while(s[i]!='\0'&&s[i]!='.'){
			tmp[count++]=s[i++];
//			printf("%c",tmp[count-1]);
		}
		printf("%s\n",tmp);
		memset(tmp, 0, sizeof(tmp));
		i++; 
	}
}
int main(){
	char s[]="192.23.32";
	split(s);
}

到此这篇关于通过C语言判断字符串是否为点分十进制的IP地址的文章就介绍到这了,更多相关C语言判断字符串是否为IP地址内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯