【几个程序小结】指针 常错题、sizeof()运算、统计二进制中1的个数


三个比较有质量的程序问题,一些说明都直接在代码里,废话不多说,直接看题
👇👇

一、指针常错题

#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 型 是四个字节

运行结果
👇👇
1

二、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()和另一个数运算时(比较大小/加减乘除)会把另一个数转换成无符号数

运行结果
👇👇
2

三、统计二进制中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循环几次

运行结果
👇👇
3
4

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

王某壬

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值