1.计算字符串长度和其存储字节数
可以用库函数strlen来计算,获取对应字符串的有效长度,注意对应头文件<string.h>
计算字符串长度:'\0'不计算在内。
计算字符串存储字节数:'\0'计算在内。如果不输入'\0'则输出结果随机。
#include <stdio.h>
#include <string.h>
int main()
{
char arr[] = { 'b', 'i', 't' };
printf("%d\n", strlen(arr));//42(随机值)
printf("%d\n", strlen("abcdef");//6
return 0;
}
其中,字符串“abcdef”的存储方式为:a b c e d f \0。所以求字符串长度为6,存储字节数为7.
2.计算字符串长度与转义字符结合
转义字符会形成一个空格,如:
#include <stdio.h>
#include <string.h>
int main()
{
printf("%d\n", strlen("c:\test\121"));
return 0;
}
在该字符串中,'\t'是转义字符水平制表,跳到下一个tab的位置;
'\121':121是八进制数,对应十进制数81,'\121'即ASCII码值为81的字符'Q';
所
以实际字符串为:c: estQ 所以只有7个字符。
3.将三个整数从小到大输出
可以用冒泡排序来解决这个问题。
冒泡排序的基本逻辑:待排序的一组数据,从前到后依次对相邻两个值进行比较,逆序则交换,使较大的值从前向后移动。
#include <stdio.h>
int main()
{
int a;
int b;
int c;
scanf("%d%d%d",&a, &b,&c);
if(a<b)
{
int tmep = a;
a = b;
b = tmep;
}
if(a<c)
{
int tmep = a;
a = c;
c = tmep;
}
if(b<c)
{
int tmep = b;
b = c;
c = tmep;
}
printf("a=%d b=%d c=%d\n", a, b, c);
return 0;
}
9万+





