#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
Project20240701二级指针部分作业
第2题
作业标题
下面哪个是指针数组:( A )
作业内容
A. int* arr[10];
B.int* arr[];//未指定数组大小
C.int** arr;//二级指针
D.int(*arr)[10];//这里的*arr被()括起来了,代表着arr是一个指针,而[10]代表含有10个元素的数组,即(*arr)[10]为数组指针。
第3题
作业标题
如有以下代码:
struct student
{
int num;
char name[32];
float score;
}stu;
则下面的叙述不正确的是:( D )
作业内容
A.struct 是结构体类型的关键字
B.struct student 是用户定义的结构体类型
C.num, score 都是结构体成员名
D.stu 是用户定义的结构体类型名//错:应该是结构体变量
注意:
typedef struct Student
{
int num;
char name[32];
float score;
}Stu;//区别于题目中的stu,这里的typedef对类型重命名产生的Stu,即Stu是类型,Stu可以用来创建变量。
int main()
{
Stu s1;
return 0;
}
第4题
作业标题
下面程序要求输出结构体中成员a的数据, 以下不能填入横线处的内容是( A )
#include < stdio.h >
struct S
{
int a;
int b;
};
int main()
{
struct S a, * p = &a;
a.a = 99;
printf("%d\n", __________);
return 0;
}
作业内容
A.a.a
B.*p.a
C.p->a
D.(*p).a
解析:
①struct S a, * p = &a;这里等价于:
struct S a;
struct S p;
pa = &a;
②a.a:a成员里的a
③*p.a:'.'的优先级高于'*'
④p->a:结构体指针->a 结构体成员的访问
⑤(*p).a:参考结构体成员的访问
第5题
作业标题
下面程序的输出结果是:( C )
struct stu
{
int num;
char name[10];
int age;
};
void fun(struct stu* p)
{
printf("%s\n", (*p).name);
return;
}
int main()
{
struct stu students[3] = { {9801,"zhang",20},
{9802,"wang",19},
{9803,"zhao",18} };
fun(students + 1);
return 0;
}
作业内容
A.zhang
B.zhao
C.wang
D.18
第7题
作业标题
喝汽水问题
作业内容
喝汽水,1瓶汽水1元,2个空瓶可以换一瓶汽水,给20元,可以喝多少汽水(编程实现)。
方法一:
int main()
{
int money = 0;
int total = 0;
int empty = 0;
scanf("%d", &money);
total += money;//花钱买的
empty = money;//买的喝完剩下的空瓶数
//空瓶换汽水
while (empty >= 2)
{
total += (empty / 2);
empty = empty / 2 + empty % 2;
}
printf("%d\n", total);
return 0;
}
方法二:
数学逻辑:
int main()
{
int money = 0;
int total = 0;
int empty = 0;
scanf("%d", &money);
if (money > 0)
total = 2 * money - 1;
printf("%d\n", total);
return 0;
}
第8题
作业标题
BC106 - 上三角矩阵判定
作业内容
描述
KiKi想知道一个n阶方矩是否为上三角矩阵,请帮他编程判定。
上三角矩阵即主对角线以下的元素都为0的矩阵,主对角线为从矩阵的左上角至右下角的连线。
输入描述:
第一行包含一个整数n,表示一个方阵包含n行n列,用空格分隔。(1≤n≤10)
从2到n + 1行,每行输入n个整数(范围 -2^31~2^31 - 1),用空格分隔,共输入n * n个数。
输出描述:
一行,如果输入方阵是上三角矩阵输出"YES"并换行,否则输出"NO"并换行。
示例
输入:
3
1 2 3
0 4 5
0 0 6
输出:
YES
int main()
{
int n = 0;
scanf("%d", &n);
int arr[n][n];//C99 变长数组
//∵题中给了n的quzhifanwei
//∴VS可以写成:
// int arr[10][10];
int i = 0;
for (i = 0; i < n; i++)
{
int j = 0;
for (j = 0; j < n; j++)
{
scanf("%d", &arr[i][j]);
}
}
//判断:
int flag = 1;//默认矩阵是上三角方阵
for (i = 0; i < n; i++)
{
int j = 0;
for (j = 0; j < i; j++)
{
if (arr[i][j] != 0)
{
flag = 0;
goto end;
}
}
}
end:
if (flag == 1)
printf("YES\n");
else
printf("NO\n");
return 0;
}
第9题
作业标题
BC105 - 矩阵相等判断
作业内容
描述
KiKi得到了两个n行m列的矩阵,他想知道两个矩阵是否相等,请你回答他。(当两个矩阵对应数组元素都相等时两个矩阵相等)。
输入描述:
第一行包含两个整数n和m,表示两个矩阵包含n行m列,用空格分隔。
从2到n + 1行,每行输入m个整数(范围 - 231~231 - 1),用空格分隔,共输入n * m个数,表示第一个矩阵中的元素。
从n + 2行到2n + 1,每行输入m个整数(范围 - 231~231 - 1),用空格分隔,共输入n * m个数,表示第二个矩阵中的元素。
1 < n, m < 10
输出描述:
一行,如果两个矩阵相等输出"Yes"并换行,否则输出"No"并换行。
示例
输入:
2 2
1 2
3 4
1 2
3 4
输出:
Yes
int main()
{
int n = 0;
int m = 0;
scanf("%d %d", &n, &m);
int arr1[n][m];
int arr2[n][m];
int i = 0;
int j = 0;
for (i = 0; i < n; i++)
{
for (j = 0; j < m; j++)
{
scanf("%d", &arr1[i][j]);
}
}
for (i = 0; i < n; i++)
{
for (j = 0; j < m; j++)
{
scanf("%d", &arr2[i][j]);
}
}
//比较
int flag = 1;//默认两个矩阵相等
for (i = 0; i < n; i++)
{
for (j = 0; j < m; j++)
{
if (arr1[i][j] != arr2[i][j])
{
flag = 0;
goto end;
}
}
}
end:
if (flag == 1)
printf("Yes\n");
else
printf("No\n");
return 0;
}
简化版
int main()
{
int n = 0;
int m = 0;
scanf("%d %d", &n, &m);
int arr1[n][m];
int arr2[n][m];
int i = 0;
int j = 0;
for (i = 0; i < n; i++)
{
for (j = 0; j < m; j++)
{
scanf("%d", &arr1[i][j]);
}
}
int flag = 1;
for (i = 0; i < n; i++)
{
for (j = 0; j < m; j++)
{
scanf("%d", &arr2[i][j]);
if (arr1[i][j] != arr2[i][j])
{
flag = 0;
goto end;
}
}
}
end:
if (flag == 1)
printf("Yes\n");
else
printf("No\n");
return 0;
}