算法笔记--http://codeup.cn/problem.php?cid=100000571

1.题目描述
输入a和b两个整数,按先大后小的顺序输出a和b。注意请使用指针变量的方式进行比较和输出。

输入
两个用空格隔开的整数a和b。

输出
按先大后小的顺序输出a和b,用空格隔开。
请注意行尾输出换行。

样例输入
5 9
样例输出
9 5

#include<stdio.h>

 void main() {
     int a,b;
     scanf("%d%d",&a,&b);
     int *c,*d;
     c=&a;
     d=&b;
     if(*c>*d)
        printf("%d %d\n",*c,*d);
     else
        printf("%d %d\n",*d,*c);

 }



2.题目描述
输入a、b、c三个整数,按先大后小的顺序输出a、b和c。注意请使用指针变量的方式进行比较和输出。

输入
三个用空格隔开的整数a、b和c。

输出
按先大后小的顺序输出a、b和c,用空格隔开。
请注意行尾输出换行。

样例输入
9 0 10
样例输出
10 9 0

#include<stdio.h>
void max(int *a,int *b){
    int p;
    if(*a<*b){
        p=*a;
        *a=*b;
        *b=p;
    }

}
 void main() {
     int a,b,c;
     scanf("%d%d%d",&a,&b,&c);
     int *d,*e,*f;
     d=&a;
     e=&b;
     f=&c;
     max(e,f);
     max(d,e);
     max(e,f);
     printf("%d %d %d\n",*d,*e,*f);


 }



3.题目描述
给定字符串定义char *a = “I love China!”,读入整数n,输出在进行了a = a + n这个赋值操作以后字符指针a对应的字符串。

输入
一个整数n,保证0<=n<13.

输出
输出进行了题目描述中赋值操作之后a对应的字符串。
请注意行尾输出换行。

样例输入
7
样例输出
China!
GPLv2 licensed by HUSTOJ 2020
请到 HUSTOJ 来,给我们加个Star!

#include<stdio.h>
#include<string.h>

 void main() {
    char *a="I love China!";
    int n;
    scanf("%d",&n);
    for(int i=n;i<13;i++){
        printf("%c",*(a+i));
    }

 }



4.题目描述
输入3个字符串,按从小到大的顺序输出。要求使用指针的方法进行处理。

输入
3行,每行一个用字符串。保证每个字符串的长度不超过20。

输出
按从小到大的顺序输出这3个字符串,每个字符串一行。
请注意行尾输出换行。

样例输入
China
CLOCK
deal
样例输出
CLOCK
China
deal

#include<stdio.h>
#include<string.h>
#define N 20
void swap(char **a,char **b){
    char *t;
    t=*a;
    *a=*b;
    *b=t;
}
 void main() {
    char a[N],b[N],c[N];
    char *d,*e,*f;
    scanf("%s%s%s",a,b,c);
    d=a;
    e=b;
    f=c;
    if(strcmp(d,e)>0) swap(&d,&e);
    if(strcmp(e,f)>0) swap(&e,&f);
    if(strcmp(d,e)>0) swap(&d,&e);
    printf("%s\n%s\n%s\n",d,e,f);

 }



5.题目描述
输入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>
#include<string.h>
#define N 10

void sc(int *p){
    for(int i=0;i<N;i++){
        scanf("%d",(p+i));
    }
}
void deal(int *p){
    int min=*p,max=*p;
    int temp,m=0,n=0;
    for(int i=1;i<N;i++){
    if(*(p+i)<min){
        min=*(p+i);
        m=i;
    }
    else if(*(p+i)>max){
        max=*(p+i);
        n=i;
    }
    }
    //printf("%d %d",max,min);
    if(min!=*p){
        temp=*p;
        *p=*(p+m);
        *(p+m)=temp;
    }
    if(max!=*(p+9)){
        temp=*(p+9);
        *(p+9)=*(p+n);
        *(p+n)=temp;
    }

}

void out(int *p){
    for(int i=0;i<N;i++){
        printf("%d ",*(p+i));
    }
    printf("\n");
}
void main(){
    int a[N];
    memset(a,0,sizeof(a));
    sc(a);
    deal(a);
    out(a);
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值