指针进阶(移动云启)

本文详细解析了如何使用指针实现三个任务:1. 通过指针函数找出数组中最高分;2. 用指针表示地址输出数组元素;3. 指针实现数组的循环移动。通过实例演示和代码片段,帮助读者掌握指针在C语言中的关键应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

第1关:输出若干个学生成绩中的最高分.要求用指针函数实现

100

  • 任务要求
  • 评论267

任务描述

题目描述:读入n(1 <= n <= 1000)个学生的成绩,成绩都为整数,用指针函数求出若干个学生成绩的最高分。用数组名作为函数参数,指针作为函数返回值。 ####相关知识(略) ####编程要求 请仔细阅读右侧代码,结合相关知识,在Begin-End区域内进行代码补充。 输入

第一行为整数n,代表学生的数量。

第二行为n个学生的成绩,n个整数之间用一个空格隔开。 输出

输出最高分,占一行。 ####测试说明 样例输入:

5 80 90 85 95 91 样例输出:

95


开始你的任务吧,祝你成功!

#include<stdio.h>
/*********Begin*********/
int *Max(int *s,int n){
    int *p=s;
    for(int i=0;i<n;i++){
        if(*p<s[i]){
            *p=s[i];
        }
    }
    return *p;
}
/*********End**********/
int main(void)
{
    int n,s[110];
    scanf("%d",&n);
    for(int i=0;i<n;i++)
        scanf("%d",&s[i]);
    int ans;
	/*********Begin*********/
    ans=Max(s,n);
	/*********End**********/
    printf("%d",ans );
    return 0;
}

第2关:采用指针变量表示地址的方法输入输出数组中的个元素

100

  • 任务要求
  • 参考答案
  • 评论267

任务描述

题目描述:采用指针变量表示地址的方法输入输出数组中的个元素

第一行为n,表示n个整数,

第二行为n个整数。

相关知识(略)

编程要求

请仔细阅读右侧代码,结合相关知识,在Begin-End区域内进行代码补充。 输入

第一行为n,表示n个整数,

第二行为n个整数。 输出

用指针变量表示地址的方法输出数组中的各个元素。

输出占一行,两个整数之间有空格 ####测试说明 样例输入:

10 1 2 3 4 5 6 7 8 9 10 样例输出:

1 2 3 4 5 6 7 8 9 10


开始你的任务吧,祝你成功!

#include<stdio.h>
int main(void)
{
	/*********Begin*********/
    int n,a[100];
    scanf("%d",&n);
    for(int i=0;i<n;i++){
        scanf("%d",&a[i]);
    }
    int *p=a;
    for(*p;p<(a+n);p++){
        printf("%d ",*p);
    }
	/*********End**********/
    return 0;
}

第3关:用指针实现数组循环移动

100

  • 任务要求
  • 参考答案
  • 评论267

任务描述

题目描述:有n个整数,要求你编写一个函数使其向右循环移动m个位置 ####相关知识(略) ####编程要求 请仔细阅读右侧代码,结合相关知识,在Begin-End区域内进行代码补充。 输入 输入n m表示有n个整数,移动m输出 输出移动后的数组 ####测试说明 样例输入: 10 5 1 2 3 4 5 6 7 8 9 0 样例输出: 6 7 8 9 0 1 2 3 4 5


开始你的任务吧,祝你成功!

#include<stdio.h>
int *solve(int *s,int n,int m){
    /*********Begin*********/
    int i,a[100],count=0,*b;
    int *p=s+n-m;//定义指针p的首地址
    for(*p;p<s+n;p++){
        a[count++]=*p;
    }
    p=s;//重新定义指针p的首地址
    for(*p;p<s+n-m;p++){
        a[count++]=*p;
    }
    b=a;
    return b;
    /*********End**********/
}
int main(void)
{
    int n,m,s[110];
    scanf("%d%d",&n,&m);
    for(int i=0;i<n;i++)
        scanf("%d",&s[i]);
    int *ans;
    /*********Begin*********/
    ans=solve(s,n,m);
    /*********End**********/
    for(int i=0;i<n;i++){
        if(i==0)    printf("%d",*ans++ );
        else    printf(" %d",*ans++ );
    }
    return 0;
}

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值