复习c语言——面试题

简单直接排序

#include<stdio.h>
int main()
{
    int a[]={70,30,40,10,80,20,90,100,60};
    int n=sizeof(a)/sizeof(a[0]);
    int i,j,temp;
    printf("原数组为:") ;
    for(i=0;i<n;++i)
        printf("%d ",a[i]) ;
    printf("\n\n") ;
	for(i = 1; i < n; i++)
	{
			temp = a[i];
			for(j = i;j > 0 && a[j - 1]>temp;j--)
			{
				a[j]=a[j - 1];
			}
			a[j]=temp;
	}
	printf("排序后数组:") ;
    for(i=0;i<n;i++)
        printf("%d ",a[i]);
    printf("\n") ;
    return 0;
}

将一个3x3的数组转置

void printf_a(int a[][3], int col, int raw);
void zhuanzhi(int (*a)[3]);
int main()
{
	int a[3][3] = {1,2,3,
				   4,5,6,
				   7,8,9};
	printf_a(a, 3, 3);
	//Transpose(a,3,3);
	zhuanzhi(a);
	printf_a(a, 3, 3);
	return 0;	
}



void printf_a(int a[][3], int col, int raw)
{
	int i,j;
	for(i = 0; i < col; i++)
	{
		for(j = 0; j < raw; j++)
		{
			printf("%d ", a[i][j]);
		}
		printf("\n");
	}
	printf("******************\n");
}
void zhuanzhi(int (*a)[3])
{
	int i,j,t;
	for(i=0;i<2;i++)
		for(j=1;j<3;j++)
		{
			t=*(*(a+i)+j);
			*(*(a+i)+j)=*(*(a+j)+i);
		  *(*(a+j)+i)=t;
		}

2.有一数组,int a[4] = {1,2,3,4}; *((int *)(&a + 1) - 1)的结果是:
答:4
这个问题的关键是理解 &a
a是一个数组名,也就是数组的首地址。
对a进行取地址运算符,得到的是一个指向数组的指针!!!!这句话尤为重要!
也就相当于
int (*p) [4] = &a;
p是一个指针,它指向的是一个包含4个int元素的数组!!
(&a + 1) 相当于p的偏移量相当于 p + sizeof(int) * 4
而程序中强制将指针(int *(&a + 1))转换成一个(int) 那么 p -1 其实就是 p - sizeof(int)。所以,再-1 指向了数组中得最后一个元素,也就是 4。

4.写一个宏函数,功能:求结构体(struct type)成员(mem)相对于其首地址的偏移地址
#define STRUCT_OFFSET(type, mem) (( size_t ) &(( struct type*) 0 )->mem)

因为是求偏移量 所以假设结构体的首地址是0开始,把他转换成结构体指针类型,在用->取得他的成员,前面加了一个& 就是取得这个成员的地址,最后在强制转换成size_t,这样就得到了偏移量。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值