10.1
题目描述
输入a和b两个整数,按先大后小的顺序输出a和b。注意请使用指针变量的方式进行比较和输出。输入
两个用空格隔开的整数a和b。输出
按先大后小的顺序输出a和b,用空格隔开。
请注意行尾输出换行。样例输入
5 9- 样例输出
9 5
#include <stdio.h>
void cmp(int* a, int* b)
{
if (*a < *b)
printf("%d %d",*b, *a);
else
printf("%d %d",*a, *b);
}
int main()
{
int a,b;
int *p1 = &a;
int *p2 = &b;
scanf("%d %d",p1, p2);
cmp(p1, p2);
return 0;
}
10.2
题目描述
输入a、b、c三个整数,按先大后小的顺序输出a、b和c。注意请使用指针变量的方式进行比较和输出。输入
三个用空格隔开的整数a、b和c。输出
按先大后小的顺序输出a、b和c,用空格隔开。
请注意行尾输出换行。样例输入
9 0 10样例输出
10 9 0引用是对p1,p2,p3的修改,并不改变a,b,c的地址;修改函数传入的实参变量(引用);
#include <stdio.h>
void swap(int* &a, int* &b)
{
int* temp = a;
a = b;
b = temp;
}
int main()
{
int a, b, c;
int *p1=&a,*p2=&b,*p3=&c;
scanf("%d %d %d",p1,p2,p3);
if (a < b)
swap(p1, p2);
if (a < c)
swap(p1, p3);
if (b < c)
swap(p2, p3);
printf("%d %d %d\n",*p1,*p2,*p3);
printf("%d %d %d\n",p1,p2,p3);
printf("%d %d %d\n",&a,&b,&c);
}
输入 1 2 4
输出 4 2 1
p1,p2 p3的地址已经发生了改变
1549352380 1549352376 1549352372
1549352372 1549352376 1549352380
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 s[14] = "I love China!";
char* a = s;
int n;
scanf("%d",&n);
while(n >= 0 && n < 13)
{
printf("%c",*(a+n));
n++;
}
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 = a;
a = b;
b = temp;
}
int main()
{
char s1[21],s2[21],s3[21];
char *p1 = s1,*p2 = s2,*p3 = s3;
gets(s1);
gets(s2);
gets(s3);
if (strcmp(s1, s2)>0)
swap(p1,p2);
if (strcmp(s1, s3)>0)
swap(p1, p3);
if (strcmp(s2, s3)>0)
swap(p2, p3);
puts(p1);
puts(p2);
puts(p3);
return 0;
}
10.16
题目描述
输入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 a[])
{
int i;
for (i=0;i<10;i++)
scanf("%d",&a[i]);
}
void ouput(int a[])
{
int i;
for (i=0;i<10;i++)
printf("%d ",a[i]);
printf("\n");
}
int find_max(int a, int b)
{
if (a>b)
return a;
else
return b;
}
int find_min(int a, int b)
{
if (a>b)
return b;
else
return a;
}
int main()
{
int a[10],temp=a[0],i,max,min;
input(a);
for (i=1;i<10;i++)
{
max = find_max(temp, a[i]);
temp = max;
}
temp = a[0];
for (i=1;i<10;i++)
{
min = find_min(temp, a[i]);
temp = min;
}
for (i=0;i<10;i++)
{
if (a[i] == max){
temp = a[i];
a[i] = a[9];
a[9] = temp;
} else if(a[i] == min)
{
temp = a[i];
a[i] = a[0];
a[0] = temp;
}
}
ouput(a);
return 0;
}