c语言:sprintf() 函数用法示例

sprintf() 是一个C语言标准库中的函数,它的原型定义在头文件 中。该函数用于将格式化的数据写入字符串中。

函数原型如下:

int sprintf(char *str, const char *format, ...);

其中,str 是一个字符数组,用于接收格式化后的数据;format 是一个格式化字符串,指定了要输出的数据的格式;…
表示可变参数,用于提供需要格式化的数据。

sprintf() 函数的作用是按照指定的格式将数据转换为字符串,并存储在 str 中。它的使用方式类似于 printf()
函数,但不会将结果打印到标准输出流,而是将结果写入到指定的字符串中。

这段代码的功能是接收两个浮点数 x 和 y 的输入,并计算它们的商 x/y,然后按一定格式输出。

具体来说,代码首先通过 scanf() 函数接收两个浮点数的输入,如果第二个数 y 等于0,则输出错误提示信息,并结束程序运行。接着,代码通过 sprintf() 函数将计算得到的商 x/y 格式化为字符串,其中 “% -12.6f” 表示左对齐、总宽度为12、小数点后保留6位的浮点数格式。将格式化后的字符串存储在 s 字符数组中。

接下来,代码使用 strlen() 函数获取 s 的长度,并从末尾开始遍历字符串,将结尾处连续的空格、0、小数点字符(‘.’)替换成’\0’,即添加字符串结束符。如果遇到了非空格/非0/非小数点字符,则停止替换操作。最后,代码使用 printf() 函数输出格式化后的字符串。

例如,假设输入 x=1.23, y=4.56,则计算得到的商 x/y 约为0.2697。经过格式化后,字符串 s 的值为 "0.269700 "(包含3个空格),在替换操作之后变成 “0.2697”(不包含空格)。

#include 
int main()
{
	int i,Len;
	float x,y;
	char s[20];
	scanf("%f %f",&x,&y);
	if(y==0)
	{
		printf("分母不能为0!\n");
		return;
	}
	sprintf(s,"% -12.6f",x/y);  // sprintf() 函数将计算得到的商 x/y 格式化为字符串,其中 "% -12.6f"
	//- 表示左对齐、总宽度为12、小数点后保留6位的浮点数格式。将格式化后的字符串存储在 s 字符数组中。
	Len=strlen(s);
	for(i=Len-1;i>-1;i--)
	{
		if(s[i]==32||s[i]=='0'||s[i]=='.') s[i]=0; //从末尾开始遍历字符串,将结尾处连续的空格、0、小数点字符('.')替换成'\0',
		else break;
	}
	printf("[%s]\n",s); //假设输入 x=1.23, y=4.56,则计算得到的商 x/y 约为0.2697。
	//经过格式化后,字符串 s 的值为 "0.269700    "(包含3个空格),在替换操作之后变成 "0.2697"(不包含空格)。
	return 0;
 } 

你可能感兴趣的:(c语言,c语言,算法,开发语言)