1.题目描述
输入a和b两个整数,按先大后小的顺序输出a和b。注意请使用指针变量的方式进行比较和输出。
输入
两个用空格隔开的整数a和b。
输出
按先大后小的顺序输出a和b,用空格隔开。
请注意行尾输出换行。
样例输入
5 9
样例输出
9 5
#include<stdio.h>
void main() {
int a,b;
scanf("%d%d",&a,&b);
int *c,*d;
c=&a;
d=&b;
if(*c>*d)
printf("%d %d\n",*c,*d);
else
printf("%d %d\n",*d,*c);
}
2.题目描述
输入a、b、c三个整数,按先大后小的顺序输出a、b和c。注意请使用指针变量的方式进行比较和输出。
输入
三个用空格隔开的整数a、b和c。
输出
按先大后小的顺序输出a、b和c,用空格隔开。
请注意行尾输出换行。
样例输入
9 0 10
样例输出
10 9 0
#include<stdio.h>
void max(int *a,int *b){
int p;
if(*a<*b){
p=*a;
*a=*b;
*b=p;
}
}
void main() {
int a,b,c;
scanf("%d%d%d",&a,&b,&c);
int *d,*e,*f;
d=&a;
e=&b;
f=&c;
max(e,f);
max(d,e);
max(e,f);
printf("%d %d %d\n",*d,*e,*f);
}
3.题目描述
给定字符串定义char *a = “I love China!”,读入整数n,输出在进行了a = a + n这个赋值操作以后字符指针a对应的字符串。
输入
一个整数n,保证0<=n<13.
输出
输出进行了题目描述中赋值操作之后a对应的字符串。
请注意行尾输出换行。
样例输入
7
样例输出
China!
GPLv2 licensed by HUSTOJ 2020
请到 HUSTOJ 来,给我们加个Star!
#include<stdio.h>
#include<string.h>
void main() {
char *a="I love China!";
int n;
scanf("%d",&n);
for(int i=n;i<13;i++){
printf("%c",*(a+i));
}
}
4.题目描述
输入3个字符串,按从小到大的顺序输出。要求使用指针的方法进行处理。
输入
3行,每行一个用字符串。保证每个字符串的长度不超过20。
输出
按从小到大的顺序输出这3个字符串,每个字符串一行。
请注意行尾输出换行。
样例输入
China
CLOCK
deal
样例输出
CLOCK
China
deal
#include<stdio.h>
#include<string.h>
#define N 20
void swap(char **a,char **b){
char *t;
t=*a;
*a=*b;
*b=t;
}
void main() {
char a[N],b[N],c[N];
char *d,*e,*f;
scanf("%s%s%s",a,b,c);
d=a;
e=b;
f=c;
if(strcmp(d,e)>0) swap(&d,&e);
if(strcmp(e,f)>0) swap(&e,&f);
if(strcmp(d,e)>0) swap(&d,&e);
printf("%s\n%s\n%s\n",d,e,f);
}
5.题目描述
输入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>
#define N 10
void sc(int *p){
for(int i=0;i<N;i++){
scanf("%d",(p+i));
}
}
void deal(int *p){
int min=*p,max=*p;
int temp,m=0,n=0;
for(int i=1;i<N;i++){
if(*(p+i)<min){
min=*(p+i);
m=i;
}
else if(*(p+i)>max){
max=*(p+i);
n=i;
}
}
//printf("%d %d",max,min);
if(min!=*p){
temp=*p;
*p=*(p+m);
*(p+m)=temp;
}
if(max!=*(p+9)){
temp=*(p+9);
*(p+9)=*(p+n);
*(p+n)=temp;
}
}
void out(int *p){
for(int i=0;i<N;i++){
printf("%d ",*(p+i));
}
printf("\n");
}
void main(){
int a[N];
memset(a,0,sizeof(a));
sc(a);
deal(a);
out(a);
}