目录
问题 A: C语言10.1
题目描述
输入a和b两个整数,按先大后小的顺序输出a和b。注意请使用指针变量的方式进行比较和输出。
输入
两个用空格隔开的整数a和b。
输出
按先大后小的顺序输出a和b,用空格隔开。
请注意行尾输出换行。
样例输入
5 9
样例输出
9 5
题解
#include <stdio.h>
#include <string.h>
#include <math.h>
int main(){
int a, b;
scanf("%d%d", &a, &b);
int *p1, *p2;
p1 = &a;
p2 = &b;
if(*p1 < *p2){
printf("%d %d\n", *p2, *p1);
}
else{
printf("%d %d\n", *p1, *p2);
}
return 0;
}
问题 B: C语言10.2
题目描述
输入a、b、c三个整数,按先大后小的顺序输出a、b和c。注意请使用指针变量的方式进行比较和输出。
输入
三个用空格隔开的整数a、b和c。
输出
按先大后小的顺序输出a、b和c,用空格隔开。
请注意行尾输出换行。
样例输入
9 0 10
样例输出
10 9 0
题解
#include <stdio.h>
#include <string.h>
#include <math.h>
int main(){
int a, b, c;
scanf("%d%d%d", &a, &b, &c);
int *p1, *p2, *p3;
p1 = &a;
p2 = &b;
p3 = &c;
int temp;//临时变量
if(*p1 < *p2){
temp = *p1;
*p1 = *p2;
*p2 = temp;
}
if(*p2 < *p3){
temp = *p2;
*p2 = *p3;
*p3 = temp;
}
if(*p1 < *p2){
temp = *p1;
*p1 = *p2;
*p2 = temp;
}
printf("%d %d %d\n", *p1, *p2, *p3);
return 0;
}
问题 C: C语言10.10
题目描述
给定字符串定义char *a = “I love China!”,读入整数n,输出在进行了a = a + n这个赋值操作以后字符指针a对应的字符串。
输入
一个整数n,保证0<=n<13.
输出
输出进行了题目描述中赋值操作之后a对应的字符串。
请注意行尾输出换行。
样例输入
7
样例输出
China!
题解
#include <stdio.h>
#include <string.h>
#include <math.h>
int main(){
const char *a = "I love China!";//指向常量的指针
int n;
scanf("%d", &n);
printf("%s\n", a + n);
return 0;
}
问题 D: C语言10.15
题目描述
输入3个字符串,按从小到大的顺序输出。要求使用指针的方法进行处理。
输入
3行,每行一个用字符串。保证每个字符串的长度不超过20。
输出
按从小到大的顺序输出这3个字符串,每个字符串一行。
请注意行尾输出换行。
样例输入
China
CLOCK
deal
样例输出
CLOCK
China
deal
题解
#include <stdio.h>
#include <string.h>
#include <math.h>
//交换字符串
void swap(char **p1, char **p2){
char *temp;
temp = *p1;
*p1 = *p2;
*p2 = temp;
}
int main(){
char str[3][100000], *p[3];
int i, j;
for(i = 0; i < 3; i++){
scanf("%s", str[i]);
p[i] = str[i];
}
for(i = 0; i < 3; i++){
for(j = 0; j < 2 - i; j++){
if(strcmp(p[j], p[j + 1]) > 0){
swap(&p[j], &p[j + 1]);
}
}
}
for(i = 0; i < 3; i++){
printf("%s\n", p[i]);
}
return 0;
}
问题 E: C语言10.16
题目描述
输入10个整数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换。要求用3个函数实现,分别为输入10个数、进行处理、输出10个数。要求使用指针的方法进行处理。
输入
用空格隔开的10个整数。
输出
输出进行题目描述操作之后的10个整数,每个整数之后输出一个空格。
请注意行尾输出换行。
样例输入
1 5 2 4 9 0 3 8 7 6
样例输出
0 5 2 4 6 1 3 8 7 9
题解
#include <stdio.h>
#include <string.h>
#include <math.h>
//输入
void gets(int a[]){
int i;
for(i = 0; i < 10; i++){
scanf("%d", &a[i]);
}
}
//处理
void deal(int a[]){
int min = a[0], max = a[9];
int i;
int minnum, maxnum;//最小值的位置,最大值的位置
for(i = 0; i < 10; i++){
if(a[i] < min){
min = a[i];
minnum = i;
}
if(a[i] > max){
max = a[i];
maxnum = i;
}
}
int temp;
temp = a[0];
a[0] = a[minnum];
a[minnum] = temp;
temp = a[9];
a[9] = a[maxnum];
a[maxnum] = temp;
}
//输出
void puts(int a[]){
int i;
for(i = 0; i < 10; i++){
printf("%d ", a[i]);
}
printf("\n");
}
int main(){
int a[10];
gets(a);
deal(a);
puts(a);
return 0;
}