当前位置: 首页 > article >正文

c语言上机小练(有点难)

1.题目

  用指向数组的指针编程实现:输入一个字符串,内有数字和非数字符号,如:a123x456(此处一个空格)17960?302tab5876。将其中连续的数字作为一个十进制整数,依次存放到一个数组a中。例如:123放在a[0]中,456放在a[1]中,17960放在a[2]中,……并统计共有多少个整数,输出这些数。要求添加合适的注释。

  要求:main函数存储字符串和提取得到的一组整型数,process函数负责完成提取字符串中的连续数字字符后转换为十进制整数并存入对应数组元素中,同时返回转换得到的整数个数,如果输入空串,process函数返回-1,如果非空串,但无连续数字字符,则返回0。main函数根据process返回值决定是否展示转换成功的一组数。合理设计process函数的接口参数。

2.分析

  这道题真的是对我来说很难,是我第一次敲了两个小时的代码了,第一个小时是完成整数寻找的设计,第二个小时是对函数进行防御机制的设计,中间代码出错,一行一行调试了很久,发现调试太好用了,哭死。具体的写成注释了,不赘述。

#include<stdio.h>
#define N 100  //确定字符串最大长度

//保护机制,函数防御
int process(char* a, int c)
{
	char* p = a;
	int x = 0;
	//先判定字符串是否存在有数字,有数字的话则把x赋值为1;
	for (p; (*p) != '\0'; p++)
	{
		if (((*p) >= '0') && ((*p) <= '9'))
		{
			x = 1;
			break;
		}
	}
	//根据数组名为首元素地址判定该字符串是否为空串
	if ((*a) == '\0')
		return -1;
   //值得运行的,即既有数字又非空串
	else if (x == 1)
	{
		return 1;
	}
	//单纯只有字母,不存在数字的
	else 
		return 0;
}
//求整数部分
func(char* a, int* b, int c)
{
char *p = a;
int i = 0;
int j = 0;
int x = 0;
for (p = a; (*p) != '\0'; p++)
//对该字符串整体循环一遍
	{
		if (((*p) >= '0') && ((*p) <= '9'))
		{
			if (x == 0) 
			{
				b[i] = (*p) - 48;
				//根据数字0的ASCII码值为48换算
				i++;
			}
			else
				b[i - 1] = b[i - 1] * 10 + (*p) - 48;
			    x = 1;
		}
		else
			x = 0;
	}

}
//求主函数
int main()
{
	char a[N];
	int b[N] = { 0 };
	int j = 0;
	int flat = 0;//flat的设立是防御机制
	printf("请输入一串字符\n");
	gets(a);
	flat = process(a, N);
	if (flat == 0)
	{
		printf("该字符串中不包含整数");
	}
	else if (flat == -1)
	{
		printf("该字符串为空串");
	}
	else if (flat == 1)
	{
		func(a, b, N);
		for (j = 0; b[j] != 0; j++)
		printf("%d ", b[j]);
		printf("\n");
		printf("共有%d个", j);
	}
	return 0;

}

3.总代码

#include<stdio.h>
#define N 100  //确定字符串最大长度

//保护机制,函数防御
int process(char* a, int c)
{
	char* p = a;
	int x = 0;
	//先判定字符串是否存在有数字,有数字的话则把x赋值为1;
	for (p; (*p) != '\0'; p++)
	{
		if (((*p) >= '0') && ((*p) <= '9'))
		{
			x = 1;
			break;
		}
	}
	//根据数组名为首元素地址判定该字符串是否为空串
	if ((*a) == '\0')
		return -1;
   //值得运行的,即既有数字又非空串
	else if (x == 1)
	{
		return 1;
	}
	//单纯只有字母,不存在数字的
	else 
		return 0;
}


//求整数部分
func(char* a, int* b, int c)
{
char *p = a;
int i = 0;
int j = 0;
int x = 0;
for (p = a; (*p) != '\0'; p++)
//对该字符串整体循环一遍
	{
		if (((*p) >= '0') && ((*p) <= '9'))
		{
			if (x == 0) 
			{
				b[i] = (*p) - 48;
				//根据数字0的ASCII码值为48换算
				i++;
			}
			else
				b[i - 1] = b[i - 1] * 10 + (*p) - 48;
			    x = 1;
		}
		else
			x = 0;
	}

}


//求主函数
int main()
{
	char a[N];
	int b[N] = { 0 };
	int j = 0;
	int flat = 0;//flat的设立是防御机制
	printf("请输入一串字符\n");
	gets(a);
	flat = process(a, N);
	if (flat == 0)
	{
		printf("该字符串中不包含整数");
	}
	else if (flat == -1)
	{
		printf("该字符串为空串");
	}
	else if (flat == 1)
	{
		func(a, b, N);
		for (j = 0; b[j] != 0; j++)
		printf("%d ", b[j]);
		printf("\n");
		printf("共有%d个", j);
	}
	return 0;

}

 

 


http://www.kler.cn/a/160690.html

相关文章:

  • 缓存与数据库不一致的解决方案:深入理解与实践
  • ios swift开发--ios远程推送通知配置
  • Thread类及常见方法
  • C# 模拟浏览器自操作(自动化办公)
  • Bugku CTF_Web——文件上传
  • LLMs 如何处理相互矛盾的指令?指令遵循优先级实验
  • 【力扣】206.反转链表
  • 浅谈什么是语音芯片的白噪音支持功能:打造舒适家居与优质音频体验
  • 扔掉sql语句,用 QxOrm 让你的数据库操作从来没有这么简单过!
  • rename--统一的PRF
  • c# OpenCV 读取、显示和写入图像(二)
  • SAP ABAP 开发ALV的基本流程(ALV资料二)
  • 前端实现手机短信验证码倒计时效果
  • 【PyTorch】模型选择、欠拟合和过拟合
  • Linux命令之ps
  • QT+Unity3D 超详细(将unity3D与QT进行连接,并实现信息传递)
  • SpringSecurity6 | 默认用户生成(下)
  • Linux设置Docker自动创建Nginx容器脚本
  • IDEA如何配置Git 遇到问题的解决
  • Java 敏感信息脱敏类
  • 【开源项目】Windows串口通信组件 -- Com.Gitusme.IO.Ports.SerialPort
  • 【c语言指针详解】指针的高级应用
  • 被动式安全扫描器
  • WebGL笔记:矩阵平移的数学原理和实现
  • 内衣洗衣机和手洗哪个干净?高性价比内衣洗衣机推荐
  • 【C语言】用户空间使用非缓存内存