指针及其应用
第1关:数组倒置
200
- 任务要求
- 参考答案
- 评论93
任务描述
本关任务:程序功能是通过调用reverse()
函数按逆序重新放置数组a
中的元素值,请补全程序。
相关知识
相关知识略
编程要求
请仔细阅读右侧代码,结合相关知识,在右边提示区域内进行代码补充,完成编写数组倒置的小程序。
测试说明
平台会对你编写的代码进行测试:
测试输入: 0 1 2 3 4 5 6 7 8 9
预期输出: 9 8 7 6 5 4 3 2 1 0
开始你的任务吧,祝你成功!
#include "stdio.h"
#define N 10
void reverse(int *p, int a, int b)
{
int c;
/***** 请在以下一行填写代码 *****/
while (a<b)
{
c=*(p+a);
/***** 请在以下一行填写代码 *****/
*(p+a)=*(p+b);
*(p+b)=c;
a++;
/***** 请在以下一行填写代码 *****/
b--;
}
}
int main()
{
int a[N], i;
for (i=0; i<N; i++)
/***** 请在以下一行填写代码 *****/
scanf("%d",&a[i])
reverse(a, 0, N-1);
for (i=0; i<N; i++)
/***** 请在以下一行填写代码 *****/
printf("%d ",a[i]);
printf("\n");
return 0;
}
第2关:字符排序
200
- 任务要求
- 参考答案
- 评论93
任务描述
本关任务:对某一个长度为7
个字符的字符串, 除首、尾字符之外,要求对中间的5
个字符按ASCII
码降序排列。
例如,原来的字符串为CEAedca
,排序处理后应输出为CedcEAa
。
相关知识
相关知识略
编程要求
请仔细阅读右侧代码,结合相关知识,在右边提示区域内进行代码补充,完成编写字符排序的小程序。
测试说明
平台会对你编写的代码进行测试:
测试输入: CEAedca
预期输出: CedcEAa
开始你的任务吧,祝你成功!
#include <stdio.h>
#include <ctype.h>
#include <string.h>
int fun(char *s, int num)
{
char ch;
int i, j;
for(i = 1 ; i < 6 ; i++)
for(j = i + 1 ; j < 6 ; j++)
{
/***** 请在以下一行填写代码 *****/
if(*(s+j)>*(s+i))
{
ch = *(s + j);
*(s + j) = *(s +i);
*(s + i) = ch;
}
}
}
int main()
{
char s[10];
scanf("%s",s);
/***** 请在以下一行填写代码 *****/
fun(s,7);
printf("%s",s);
return 0;
}
第3关:找最长串
200
- 任务要求
- 参考答案
- 评论93
任务描述
本关任务:给定程序中函数fun
的功能是从N
个字符串中找出最长的那个串,并将其地址作为函数值返回。N
个字符串在主函数中输入,并放入一个字符串数组中。请改正程序中的错误,使它能得出正确结果。注意:不要改动main
函数,不得增行或删行,也不得更改程序的结构。
相关知识
相关知识略
编程要求
请仔细阅读右侧代码,结合相关知识,在右边提示区域内进行代码补充,完成编写找最长串的小程序。
测试说明
平台会对你编写的代码进行测试:
测试输入: a
bb
ccc
dddd
eeeee
预期输出: The 5 string :
a
bb
ccc
dddd
eeeee
The longest string :
eeeee
开始你的任务吧,祝你成功!
#include <stdio.h>
#include <string.h>
#define N 5
#define M 81
/***** 以下一行有错误 *****/
char *fun(char (*sq)[M])
{
int i; char *sp;
sp=sq[0];
for(i=0;i<N;i++)
if(strlen( sp)<strlen(sq[i]))
sp=sq[i];
/***** 以下一行有错误 *****/
return sp;
}
int main()
{
char str[N][M], *longest; int i;
for(i=0; i<N; i++)
scanf("%s",str[i]);
printf("The %d string :\n",N);
for(i=0; i<N; i++)
puts(str[i]);
longest=fun(str);
printf("The longest string :\n");
puts(longest);
return 0;
}
第4关:星号转移
300
- 任务要求
- 参考答案
- 评论93
任务描述
本关任务:规定输入的字符串中只包含字母和*
号。给定程序的功能是将字符串中的前导*
号全部移到字符串的尾部。请将程序补充完整,使其能正确运行得出结果。
相关知识
相关知识略
编程要求
请仔细阅读右侧代码,结合相关知识,在右边提示区域内进行代码补充,完成编写星号转移的小程序。
测试说明
平台会对你编写的代码进行测试:
测试输入: ***abcd
预期输出: abcd***
开始你的任务吧,祝你成功!
#include <stdio.h>
void fun( char *a )
{
int i=0,n=0;
char *p;
p=a;
while (*p=='*')
{
n++;
/***** 请在以下一行填写代码 *****/
p++;
}
while(*p)
{
/***** 请在以下一行填写代码 *****/
a[i]=*p;
i++;
p++;
}
while(n!=0)
{
a[i]='*';
i++;
/***** 请在以下一行填写代码 *****/
n--;
}
a[i]='\0';
}
int main()
{
char s[81];
int n=0;
scanf("%s",s);
fun( s );
printf("The string after oveing: \n");
puts(s);
return 0;
}
相关文章
- [系统安全6] PE文件知识在免杀中的应用
- 阿里云丁宇:云原生激活应用构建新范式,Serverless奇点已来
- C#编程总结(四)多线程应用
- 二、Android应用的界面编程(七)ViewAnimator及其子类[ ViewSwitcher、ImageSwitcher、TextSwitcher、ViewFlipper ]
- (算法)并查集及其应用
- MP算法、OMP算法及其在人脸识别的应用
- MongoDB开发LBS应用
- 二、Android应用的界面编程(六)ProgressBar及其子类[SeekBar、RatingBar]er
- SAP Fiori 应用 url 中的 DraftUUID 参数的含义
- Angulary应用依赖里的platform-browser
- Angular应用里具有back功能的按钮实现
- 托管小屋,爱心满满,我的第一个微搭低代码应用上线啦
- VB.net:VB.net编程语言学习之基于VB.net语言控制VS软件中的窗体(各种控件及其属性代码说明)的简介、案例应用(GUI界面设计代码案例)之详细攻略
- ML:置信区间的简介(精密度/准确度/精确度的三者区别及其关系)、使用方法、案例应用之详细攻略
- Python语言学习:在python中,如何获取变量的本身字符串名字而非其值/内容及其应用(在代码中如何查找同值的所有变量名)
- PostgreSQL relcache在长连接应用中的内存霸占"坑"
- C++:C++编程语言学习之数学运算&运算符及其优先级的简介、案例应用之详细攻略
- sklearn之pipeline:pipeline函数/make_pipeline函数的简介及其区别联系、使用技巧、案例应用之详细攻略
- DL之MobileNetV2:MobileNetV2算法的简介(论文介绍)、架构详解、案例应用等配图集合之详细攻略
- 【Android 插件化】Hook 插件化框架 ( 创建插件应用 | 拷贝插件 APK | 初始化插件包 | 测试插件 DEX 字节码 )
- cordova+vue 项目打包成Android(apk)应用
- 006-基于hyperledger fabric1.4( 官方文档)编写第一个应用【外部nodejs调用】
- TI C66x DSP 系统events及其应用 - 5.10(创建ISR的三种情况)
- Trie(前缀树/字典树)及其应用
- android 计算器系统应用深度解析
- 改进的粒子滤波算法及其应用研究(Matlab代码实现)
- 【区块链技术开发】基于Web3.js以太坊网络上的智能合约的交互及其应用