Contest100000571 - 《算法笔记》2.7小节——C/C++快速入门->指针

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,用空格隔开。
请注意行尾输出换行。

样例输入

扫描二维码关注公众号,回复: 5316155 查看本文章

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

猜你喜欢

转载自blog.csdn.net/c1014yzh/article/details/87909711