1.求 sizeof(name1)?(晟安信息)
struct name1{
char str;
short x;
int num;
};
答案:8
分析:字节对齐,最大步长int4字节,char、short分配在同一个4字节里,int跨步长重新开辟4字节合计8字节。
2.(电工时代)
typedef struct _a
{
char c1;
long i;
char c2;
double f;
}a;
typedef struct _b
{
char c1;
char c2;
long i;
double f;
}b;
sizeof(a) = _______;
sizeof(b) = _______;
答案:32 24
分析:a:最大步长8,char,c1一个字节,long跨步长重新开辟8字节,char,c2再开辟8个字节,double再开辟8个字节,合计32个字节。b:最大步长为8字节,char c1和char c2两个字节都放在第一个步长里,long8字节重新开辟8字节,double又开辟8字节合计24字节。
3.给了一个结构体,求 sizeof(struct A) = ________。 (鲁科安全,软通动力)
struct A{
char a;
char b;
char c;
short d;
int e;
short f;
}
答案:16
分析最大步长为4,abc在同一个步长里,d跨步长,在开辟4字节,e也跨步长开辟4字节,f再开辟4字节,合计16字节。
4.有一个如下的结构体,请问在64位编译器下用 sizeof(struct A) 计算出的大小是多少?( ) (鲁科安全)
struct A{
long a1;
short a2;
int a3;
int *a4;
}
A. 24 B. 28 C. 16 D. 18
答案:A
分析:最大步长8字节,a1分配8字节,a2、a3放在第二个8字节里,a4是指针放在第三个8字节里,合计24个字节。
5.有以下说明语句,则下列错误的引用 是( )。(山大华天)
struct stu
{
int no;
char name[21];
};
stu w, *p = &w;
A. w.no B*p.no C. p->no D. (*p).no
答案:B
分析:这确实不太好分析...,可能是容易导致计算机的歧义?
6.写出下述程序结果: (中维世纪)
typedef struct test
{
char x1;
short x2;
float x3;
char x4;
}TEST_T;
printf("%d", sizeof(TEST_T));
答案:12
分析:最大步长4,x1x2在第一个步长里,x3跨字节放在第二个步长x4再开一个步长,合计12个字节。
7.下面的代码输出是什么,为什么?(64位环境) (信雅达)
struct {
char *a1;
long a2;
short a3;
}A;
int main(void)
{
printf("%d", sizeof(A));
}
答案:24
分析:64位操作系统,即最大步长为8。a1是指针占8字节,long占8字节,a3虽然只占2字节但是根据字节对齐原理分配8个字节,合计24字节。
8.设有如下结构定义: struct student { int num; char name[20]; char sex; int age; char addr[30];} stud; 若用printf("%s\n", .....)访问该结构中name值的正确方法是 ( ) (杭州快越科技)
A. stud -> name B. &stud.name
C. stud.&name D. stud.name
答案:D
9.struct
{
short a; char b; float c;
}cs;
则sizeof(cs)的值是( ) (苏州特点电子科技)
A.4 B.5 C.7 D.8
答案:8
分析:最大步长4,ab再一个步长里,根据字节对齐原理,跨字节的c另开4个字节
10.如下函数的输出结果是:【 】
struct nod
{
char a; short b; char c; int d;
};
struct node s = { 3, 5, 6, 99 };
struct node *pt = &s;
printf("%X\n", *(int*)pt);
答案:63000000
分析:等待一个老师的详细解剖
11.编程题:定义学生结构体,存储学生的学号、姓名、分数,定义长度为5的结构体数组,实现:
①输入学生信息
②输出学生信息
③计算学生的成绩总分、平均分
④按照学生的分数进行排序
⑤输出排序后的数组
答案:
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#define MAX 5
typedef struct{
int id;
char name[20];
double score;
}student , *Pstu;
/*******************/
int In_Put(Pstu , int);
int Out_Put(Pstu);
int Sum_All(Pstu);
double Average_Score(Pstu);
int Sort_stu(Pstu);
/*******************/
int main(int argc, const char *argv[])
{
Pstu stu = malloc(sizeof(student)*5);
//输入学生信息
In_Put(stu , 5);
//输出总分
int sum = Sum_All(stu);
printf("总分是:%d\n" ,sum);
//输出平均分
double average = Average_Score(stu);
printf("平均分是:%.2lf\n", average);
//排序
Sort_stu(stu);
//输出学生信息
Out_Put(stu);
//释放空间
free(stu);
stu = NULL;
return 0;
}
//*
int In_Put(Pstu L , int n){
for(int i = 0 ; i<n ;i++){
printf("请输入第%d个学生信息\n" , i+1);
printf("学号:");
scanf("%d" , &(L+i)->id);
printf("姓名:");
scanf("%s", L[i].name);
printf("成绩:");
scanf("%lf" ,&(*(L+i)).score);
};
return 0;
}
int Out_Put(Pstu L){
for(int i = 0 ; i< MAX ;i++){
printf("第%d个学生的信息如下\n" , i+1);
printf("学号:%d\t" ,(*(L+i)).id);
printf("姓名:%s\t" ,(*(L+i)).name);//L[i]
printf("成绩:%.2lf\t" ,(L+i)->score);
printf("\n");
}
return 0;
}
int Sum_All(Pstu L){
int sum = 0;
for(int i = 0 ; i<MAX ; i++){
sum += L[i].score;// (L+i)->score // *(L+i).score × (*(L+i)).score√
}
return sum;
}
double Average_Score(Pstu L){
double average =(double)Sum_All(L)/MAX;
return average;
}
int Sort_stu(Pstu L ){
for(int i = 1 ; i<MAX ; i++){
for(int j = 0 ; j<MAX - i;j++){
if(L[j].score>L[j+1].score){
student temp;
temp=L[j];
L[j] = L[j+1];
L[j+1]= temp;
}
}
}
}