浮点数存储规则
根据国际标准IEEE 754,任意一个二进制浮点数V可以表示成下面的形式
1.(-1)^SM2^E
2.(-1)^S表示符号位,当S=0,V为正数,当S=1,V为负数
3.M表示有效数字,大于等于1,小于2
4.2^E表示指数位
对于32位浮点数,最高的1位是符号位S,接着的8位是指数E,剩下的23位为有效数字
对于64位浮点数,最高的1位是符号位S,接着的11位是指数E,剩下的52位为有效数字
指数E从内存中取出的情况
1.E不全为0或不全为1
指数E的计算值减去127,得到真实值,再将有效数字M前加上第一位的1
2.E全为0
浮点数的指数E等于1-127(或者1-1023)即为真实值
3.E全为1
有效数字M全为0,表示正负无穷大(正负号取决于符号位s)
判断一组数是不是有序序列
int main()
{
int n = 0;
scanf("%d", &n);
int arr[50] = { 0 };
int i = 0;
for (i = 0; i < n; i++)
{
scanf("%d", &arr[i]);
}
int flag1 = 0;
int flag2 = 0;
for (i = 0; i < n - 1; i++)
{
if (arr[i] < arr[i + 1])
flag1 = 1;
else if (arr[i] > arr[i + 1])
flag2 = 1;
}
if (flag1 + flag2 == 2)
printf("unsorted\n");
else
printf("sorted\n");
return 0;
}
获得月份的天数
int get_days_of_month(int y, int m)
{
int d = 0;
int days[] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };
d = days[m];
if ((y % 4 == 0 && y % 100 != 0) || (y % 400 == 0) && m == 2)
d += 1;
return d;
}
int main()
{
int y = 0;
int m = 0;
while (scanf("%d %d", &y, &m) == 2)
{
int d = get_days_of_month(y, m);
printf("%d\n", d);
}
return 0;
}
获得月份的天数
int get_days_of_month(int y, int m)
{
int d = 0;
int days[] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };
d = days[m];
if ((y % 4 == 0 && y % 100 != 0) || (y % 400 == 0) && m == 2)
d += 1;
return d;
}
int main()
{
int y = 0;
int m = 0;
while (scanf("%d %d", &y, &m) == 2)
{
int d = get_days_of_month(y, m);
printf("%d\n", d);
}
return 0;
}
字符串反转
输入 i am a student
输出tneduts a ma i
#include<string.h>
int main()
{
char arr[10001] = { 0 };
gets(arr);
int len = strlen(arr);
char* left = arr;
char* right = arr + len - 1;
while (left < right)
{
char tmp = *left;
*left = *right;
*right = tmp;
left++;
right--;
}
printf("%s\n", arr);
return 0;
}