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