题目描述
输入a和b两个整数,按先大后小的顺序输出a和b。注意请使用指针变量的方式进行比较和输出。
输入
两个用空格隔开的整数a和b。
输出
按先大后小的顺序输出a和b,用空格隔开。
请注意行尾输出换行。
样例输入
5 9
样例输出
9 5
参考代码
#include
int main()
{
int a,b,i;
int *a1,*b1;
a1=&a;
b1=&b;
scanf("%d%d",a1,b1);
if(*a1<*b1)
{
i=*a1;
*a1=*b1;
*b1=i;
}
printf("%d %d",*a1,*b1);
return 0;
}
题目描述
输入a、b、c三个整数,按先大后小的顺序输出a、b和c。注意请使用指针变量的方式进行比较和输出。
输入
三个用空格隔开的整数a、b和c。
输出
按先大后小的顺序输出a、b和c,用空格隔开。
请注意行尾输出换行。
样例输入
9 0 10
样例输出
10 9 0
参考代码
#include
void swap_2(int *a,int *b)
{
int temp;
temp=*a;
*a=*b;
*b=temp;
}
void swap_3(int *a,int *b,int *c)
{
if(*a<*b)
swap_2(a,b);
if(*a<*c)
swap_2(a,c);
if(*b<*c)
swap_2(b,c);
}
int main()
{
int *a1,*b1,*c1,a,b,c;
a1=&a;
b1=&b;
c1=&c;
scanf("%d%d%d",a1,b1,c1);
swap_3(a1,b1,c1);
printf("%d %d %d\n",*a1,*b1,*c1);
return 0;
}
题目描述
给定字符串定义char *a = “I love China!”,读入整数n,输出在进行了a = a + n这个赋值操作以后字符指针a对应的字符串。
输入
一个整数n,保证0<=n<13.
输出
输出进行了题目描述中赋值操作之后a对应的字符串。
请注意行尾输出换行。
样例输入
7
样例输出
China!
参考代码
#include
int main()
{
char *a="I love China!";
int n;
scanf("%d",&n);
printf("%s",a+n);
return 0;
}
题目描述
输入3个字符串,按从小到大的顺序输出。要求使用指针的方法进行处理。
输入
3行,每行一个用字符串。保证每个字符串的长度不超过20。
输出
按从小到大的顺序输出这3个字符串,每个字符串一行。
请注意行尾输出换行。
样例输入
China
CLOCK
deal
样例输出
CLOCK
China
deal
参考代码
#include
#include
#include
void swap(char** a,char** b)
{
char* temp;
temp= *a;
*a= *b;
*b=temp;
}
int main()
{
char* a, * b, * c;
a = (char*)malloc(20 * sizeof(char));
b = (char*)malloc(20 * sizeof(char));
c = (char*)malloc(20 * sizeof(char));
gets(a);
gets(b);
gets(c);
if(strcmp(a,b)>0)
swap(&a,&b);
if(strcmp(a,c)>0)
swap(&a,&c);
if(strcmp(b,c)>0)
swap(&b,&c);
puts(a);
puts(b);
puts(c);
return 0;
}
题目描述
输入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
void func(int *ary,int len)
{
int i=0;
int j=0;
int min_index=0;
int max_index=len-1;
for(i=1;i<len;i++)
{
if(*(ary+i)<*(ary+min_index))
{
min_index=i;
}
}
int temp=0;
if(min_index != 0)
{
temp=*ary;
*ary=*(ary+min_index);
*(ary+min_index)=temp;
}
for(j=len-2;j>=0;j--)
{
if(*(ary+j)>*(ary+max_index))
{
max_index=j;
}
}
if(max_index != len-1)
{
temp=*(ary+len-1);
*(ary+len-1)=*(ary+max_index);
*(ary+max_index)=temp;
}
}
void input_ary(int *ary,int len)
{
int i=0;
for(i=0;i<len;i++)
{
scanf("%d",ary+i);
}
}
void print_ary(int *ary,int len)
{
int i=0;
for(i=0;i<len;i++)
{
printf("%d ",*(ary+i));
}
printf("\n");
}
int main(void)
{
int ary[10]={0};
input_ary(ary,10);
func(ary,10);
print_ary(ary,10);
return 0;
}