C语言初阶——二级指针

#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;
}


 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值