1269 Problem A C语言10.1
题目描述
输入a和b两个整数,按先大后小的顺序输出a和b。注意请使用指针变量的方式进行比较和输出。
输入
两个用空格隔开的整数a和b。
输出
按先大后小的顺序输出a和b,用空格隔开。
请注意行尾输出换行。
样例输入
5 9
样例输出
9 5
#include<stdio.h>
int main(){
int a,b;
int *p=&a,*q=&b;
scanf("%d %d",&a,&b);
if(*p>*q){
printf("%d %d",*p,*q);
}else{
printf("%d %d",*q,*p);
}
return 0;
}
1270 Problem 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>
void comp1(int *p,int *q){
int temp=*p;
*p=*q;
*q=temp;
}
void comp2(int *i,int *j,int *k){
if(*i<*j) comp1(i,j);
if(*i<*k) comp1(i,k);
if(*j<*k) comp1(j,k);
}
int main(){
int a,b,c;
int *r1=&a,*r2=&b,*r3=&c;
scanf("%d %d %d",&a,&b,&c);
comp2(r1,r2,r3);
printf("%d %d %d",*r1,*r2,*r3);
return 0;
}
1278 Problem C C语言10.10
题目描述
给定字符串定义char *a = “I love China!”,读入整数n,输出在进行了a = a + n这个赋值操作以后字符指针a对应的字符串。
输入
一个整数n,保证0<=n<13.
输出
输出进行了题目描述中赋值操作之后a对应的字符串。
请注意行尾输出换行。
样例输入
7
样例输出
China!
#include<stdio.h>
int main(){
char* a="I love China!";
int n;
scanf("%d",&n);
if(n>=0&&n<13){
printf("%s",a+n);
}
return 0;
}
1283 Problem D C语言10.15
题目描述
输入3个字符串,按从小到大的顺序输出。要求使用指针的方法进行处理。
输入
3行,每行一个用字符串。保证每个字符串的长度不超过20。
输出
按从小到大的顺序输出这3个字符串,每个字符串一行。
请注意行尾输出换行。
样例输入
China
CLOCK
deal
样例输出
CLOCK
China
deal
#include<stdio.h>
#include<string.h>
void swap1(char *s1,char *s2){
char d[20];
char* p4=d;
strcpy(p4,s1);
strcpy(s1,s2);
strcpy(s2,p4);
}
void swap2(char *r1,char *r2,char *r3){
if(strcmp(r1,r2)>0) swap1(r1,r2);
if(strcmp(r1,r3)>0) swap1(r1,r3);
if(strcmp(r2,r3)>0) swap1(r2,r3);
}
int main(){
char a[20],b[20],c[20];
gets(a);
gets(b);
gets(c);
char *p1=a,*p2=b,*p3=c;
swap2(p1,p2,p3);
puts(p1);
puts(p2);
puts(p3);
return 0;
}
1284 Problem 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>
void input(int* p){
for(int i=0;i<10;i++){
scanf("%d",p+i);
}
}
void sort(int* p){
int min,max,t,temp;
min=*p;
max=*p;
for(int i=0;i<10;i++){
if(min>=*(p+i)){
min=*(p+i);
t=i;
}
}
temp=*(p+t);
*(p+t)=*p;
*p=temp;
for(int i=0;i<10;i++){
if(max<=*(p+i)){
max=*(p+i);
t=i;
}
}
temp=*(p+t);
*(p+t)=*(p+9);
*(p+9)=temp;
}
void output(int* p){
for(int i=0;i<10;i++){
printf("%d ",*(p+i));
}
}
int main(){
int a[10];
input(a);
sort(a);
output(a);
}