三个比较有质量的程序问题,一些说明都直接在代码里,废话不多说,直接看题
👇👇
一、指针常错题
#include<stdio.h>
int main()
{
int arr[]={1,2,3,4,5};
short* p=(short*)arr;
int i;
for(i=0;i<4;i++)
{
*(p+i)=0;
}
for(i=0;i<5;i++)
printf("%d ",arr[i]);
return 0;
}
提示:
将 int 型 强制转换成 short* 指针,short* 解引用操作 之后可以访问两个字节
int 型 是四个字节
运行结果
👇👇
二、sizeof()运算
#include<stdio.h>
int i;//全局变量不初始化,默认是0
int main()
{
i--;
if(i>sizeof(i))
//sizeof()-计算变量/类型所占内存的大小 是>=0 无符号数
//当sizeof()和另一个数运算时(比较大小/加减乘除)会把另一个数转换成无符号数
{
printf("---->\n");
}
else
printf("<--\n");
return 0;
}
sizeof()-计算变量/类型所占内存的大小 是>=0 —无符号数
当sizeof()和另一个数运算时(比较大小/加减乘除)会把另一个数转换成无符号数
运行结果
👇👇
三、统计二进制中1的个数
#include<stdio.h>
/* 方法一
int count_one(unsigned int a)//不加unsigned 负数运算错误
{
int count=0;
while(a)
{
if(a%2==1)
{
count++;
}
a=a/2;
}
return count;
}
//方法二:
int count_one(int a)
{
int count=0;
int i=0;
for(i=0;i<32;i++)
{
if(((a>>i)&1)==1)//a先右移i位,然后按位与1
{
count++;
}
}
return count;
}
*/
//方法三:
int count_one(int a)
{
int count=0;
while(a)
{
a=a&(a-1);//每执行一次去掉二进制最右边的1
count++;
}
return count;
}
int main()
{
int a;
printf("input:");
scanf("%d",&a);
//写一个函数求a的二进制(补码)表示中有几个1
int count=count_one(a);
printf("count = %d\n",count);
return 0;
}
说明:
本题给出了三种方法来 求a的二进制(补码)表示中有几个1。
方法一: unsigned 是关键,不加的话,输入负数运算错误
方法二: a先右移i位,然后按位与1,总是要循环32次
方法三: a&(a-1) 每执行一次去掉二进制最右边的1,有几个1循环几次
运行结果
👇👇