#include<stdio.h>
#define Q "His Hamlet was funny without being vulgar."
int main(void)
{
printf("He sold the painting for $%2.2f.\n", 2.345e2);//234.50
printf("%c%c%c\n", 'H', 105, '\41');//Hi!
printf("%s\nhas %d characters.\n", Q, strlen(Q));//42
printf("Is %2.2e the same as %2.2f\n", 1201.0, 1201.0);//1.20e3,1201.00
}
#include<stdio.h>
#define B "booboo"//字符串需加双引号
#define X 10
int main(void)
{
int age;
char name;
int xp;
printf("Please enter your first name.\n");
scanf("%s",&name);
printf("All right, %c, what's your age?\n",name);
scanf("%d",&age);//占位符也要正确
xp = age + X;//要定义变量
printf("That's a %s! You must be at least %d.\n",B,xp);
return 0;//返回值单词要写对
}
1.一个形如232.346、字段宽度为10的浮点数
答: %10.3f
2.一个形如2.33e+002、字段宽度为12的浮点数
答:%12.2e
3.一个字段宽度为30、左对齐的字符串
答:%-30s
4.字段宽度为15的unsigned long类型的整数
答:%15lu
5.一个形如0x8a、字段宽度为4的十六进制整数
答:%#4x
6..一个形如2.33E+02、字段宽度为12、左对齐的浮点数
答:%-12.2E
7.一个形如+232.346、字段宽度为10的浮点数
答:%+10.3f
8.一个字段宽度为8的字符串的前8个字符
答:%8.8s
9.一个字段宽度为6、最少有4位数字的十进制整数
答:%6.4d
10.一个字段宽度为7、左对齐字符串中的前5个字符
答:%-7.5s
#include<stdio.h>
#include<string.h>//strcat函数需要这个头文件
/*
1.编写一个程序,提示用户输入名和姓,然后以“名,姓”的格式打
印出来。
*/
int main(void)
{
char firstName [20];
char name [20];
char nameFirstName [40];
int lens;
printf("请输入您的姓氏\n");
scanf("%s",&firstName);
printf("请输入您的名字\n");
scanf("%s",&name);
printf("你的名字是:%s,姓氏为:%s\n",name,firstName);
//首先使用strcpy函数将name的内容复制到一个临时数组nameFirstName中,
//然后再使用strcat函数将firstName的内容追加到nameFirstName的末尾
strcpy(nameFirstName,name);
strcat(nameFirstName,firstName);
/*
a.打印名和姓,包括双引号;
b.在宽度为20的字段右端打印名和姓,包括双引号;
c.在宽度为20的字段左端打印名和姓,包括双引号;
d.在比姓名宽度宽3的字段中打印名和姓。
*/
lens = strlen(nameFirstName)+3;
printf("打印名和姓,包括双引号:\"%s\"\n",nameFirstName);
printf("b.在宽度为20的字段右端打印名和姓,包括双引号;\"%20s\"\n",nameFirstName);
printf("c.在宽度为20的字段左端打印名和姓,包括双引号\"%-20s\"\n",nameFirstName);
printf("d.在比姓名宽度宽3的字段中打印名和姓。\"%*s\"\n",lens,nameFirstName);
}
/*
3.编写一个程序,读取一个浮点数,首先以小数点记数法打印,然
后以指数记数法打印。用下面的格式进行输出(系统不同,指数记数
法显示的位数可能不同):
a.输入21.3或2.1e+001;
b.输入+21.290或2.129E+001;
*/
#include<stdio.h>
int main(void)
{
float input;
printf("请输入一个浮点数\n");
scanf("%f",&input);
printf("小数点计数法为:%f\n",input);
printf("指数计数法为%e\n",input);
}
/*
4.编写一个程序,提示用户输入身高(单位:英寸)和姓名,然后
以下面的格式显示用户刚输入的信息:
Dabney, you are 6.208 feet tall
使用float类型,并用/作为除号。如果你愿意,可以要求用户以厘
米为单位输入身高,并以米为单位显示出来。
*/
#include<stdio.h>
int main(void)
{
float tall;
char name[20];
printf("请输入您的身高有多少英寸\n");
scanf("%f",&tall);
printf("请输入您的姓名\n");
scanf("%s",name);
printf("%s,你的身高为%.2f英寸\n",name,tall);
printf("请输入您的身高为多少厘米\n");
scanf("%f",&tall);
printf("%s,你的身高为%.2f米\n",name,tall/100);
}
/*
5.编写一个程序,提示用户输入以兆位每秒(Mb/s)为单位的下载
速度和以兆字节(MB)为单位的文件大小。程序中应计算文件的下载
时间。注意,这里1字节等于8位。使用float类型,用/作为除号。该
程序要以下面的格式打印 3 个变量的值(下载速度、文件大小和下载
时间),显示小数点后面两位数字:
At 18.12 megabits per second, a file of 2.20 megabytes
downloads in 0.97 seconds.
*/
#include<stdio.h>
int main(void)
{
float speed;
float fileSize;
printf("请输入当前网络的下载速度,单位为M\n");
scanf("%f",&speed);
printf("请输入要下载的文件大小,单位为M\n");
scanf("%fileSize",&fileSize);
printf("下载速度为%.2fM每秒的下载速度,下载一个文件大小为%.2fM的文件,需要花费%.2f秒\n",speed,fileSize,fileSize/speed);
}
/*
6.编写一个程序,先提示用户输入名,然后提示用户输入姓。在一
行打印用户输入的名和姓,下一行分别打印名和姓的字母数。字母数
要与相应名和姓的结尾对齐,如下所示:
Melissa Honeybee
7 8
接下来,再打印相同的信息,但是字母个数与相应名和姓的开头
对齐,如下所示:
Melissa Honeybee
7 8
*/
#include<stdio.h>
int main(void)
{
char name[20];
char firstName[20];
printf("请输入你的名字\n");
scanf("%s",&name);
printf("请输入你的姓氏\n");
scanf("%s",&firstName);
printf("%s %s\n%*d %*d\n",name,firstName,strlen(name),strlen(name),strlen(firstName),strlen(firstName));
printf("%s %s\n%-*d %-*d\n",name,firstName,strlen(name),strlen(name),strlen(firstName),strlen(firstName));
}
/*7.编写一个程序,将一个double类型的变量设置为1.0/3.0,一个
float类型的变量设置为1.0/3.0。分别显示两次计算的结果各3次:一次
显示小数点后面6位数字;一次显示小数点后面12位数字;一次显示小
数点后面16位数字。程序中要包含float.h头文件,?显示FLT_DIG和
DBL_DIG的值。1.0/3.0的值与这些值一致吗?*/
#include<stdio.h>
#include<float.h>
int main(void)
{
double d = 1.0/3.0;
float f = 1.0/3.0;
printf("输出的double数值为:%.6f,输出float数值为: %.6f\n",d,f);
printf("输出的double数值为:%.12f,输出float数值为: %.12f\n",d,f);
printf("输出的double数值为:%.16f,输出float数值为: %.16f\n",d,f);
//
//FLT_DIG 和 DBL_DIG 被用于 printf 函数中,
//以输出单精度和双精度浮点数可以保证精确的小数位数。
//注意使用 %d 格式化字符串,因为这两个宏在C语言标准中定义为整数常量。
printf("FLT_DIG值为:%d,DBL_DIG值为:%d\n",FLT_DIG,DBL_DIG);
/*
输出的double数值为:0.333333, 输出float数值为: 0.333333
输出的double数值为:0.333333333333, 输出float数值为: 0.333333343267
输出的double数值为:0.3333333333333333,输出float数值为: 0.3333333432674408
FLT_DIG值为:6,DBL_DIG值为:15
*/
}
/*
8.编写一个程序,提示用户输入旅行的里程和消耗的汽油量。然后
计算并显示消耗每加仑汽油行驶的英里数,显示小数点后面一位数
字。接下来,使用1加仑大约3.785升,1英里大约为1.609千米,把单位
是英里/加仑的值转换为升/100公里(欧洲通用的燃料消耗表示法),
?显示结果,显示小数点后面 1 位数字。注意,美国采用的方案测量
消耗单位燃料的行程(值越大越好),而欧洲则采用单位距离消耗的
燃料测量方案(值越低越好)。使用#define 创建符号常量或使用 const
限定符创建变量来表示两个转换系数。
*/
#include<stdio.h>
int main(void)
{
const float transtToL = 3.785;
const float transtToKm= 1.609;
float mile,gallon;
double l;
printf("请输入旅行的里程,单位为英里\n");
scanf("%f",&mile);
printf("请输入旅行消耗的燃油数量,单位为加仑\n");
scanf("%f",&gallon);
printf("消耗每加仑汽油行驶的英里数为:%.1f\n",mile/gallon);
l = (gallon*transtToL)/(mile*transtToKm);
printf("一公里油耗为:%f\n",l);
printf("转换升/100公里的,为百公里油耗为:%.1f升\n",l*100);
}