C/C++[指针/引用]

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;
} 

猜你喜欢

转载自blog.csdn.net/u014281392/article/details/80541802