http://codeup.cn/contest.php?cid=100000571
Time Limit: 1 Sec Memory Limit: 32 MB
Submit: 2139 Solved: 1722
Description
输入a和b两个整数,按先大后小的顺序输出a和b。注意请使用指针变量的方式进行比较和输出。
Input
两个用空格隔开的整数a和b。
Output
按先大后小的顺序输出a和b,用空格隔开。
请注意行尾输出换行。
Sample Input
5 9
Sample Output
9 5
代码(C语言)
#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);
}
printf("\n");
return 0;
}
Time Limit: 1 Sec Memory Limit: 32 MB
Submit: 1911 Solved: 1450
Description
输入a、b、c三个整数,按先大后小的顺序输出a、b和c。注意请使用指针变量的方式进行比较和输出。
Input
三个用空格隔开的整数a、b和c。
Output
按先大后小的顺序输出a、b和c,用空格隔开。
请注意行尾输出换行。
Sample Input
9 0 10
Sample Output
10 9 0
代码(C语言)
#include<stdio.h>
int main(){
int a,b,c;
int *i = &a,*j = &b,*k = &c;
scanf("%d %d %d",&a,&b,&c);
if(*i > *j){
if(*j > *k) printf("%d %d %d",*i,*j,*k);
else if((*k>*i)&&(*i>*j)) printf("%d %d %d",*k,*i,*j);
else printf("%d %d %d",*i,*k,*j);
}else {
if(*i > *k) printf("%d %d %d",*j,*i,*k);
else if((*j>*k)&&(*k>*i)) printf("%d %d %d",*j,*k,*i);
else printf("%d %d %d",*k,*j,*i);
}
printf("\n");
return 0;
}
Time Limit: 1 Sec Memory Limit: 32 MB
Submit: 2298 Solved: 1540
Description
给定字符串定义char *a = “I love China!”,读入整数n,输出在进行了a = a + n这个赋值操作以后字符指针a对应的字符串。
Input
一个整数n,保证0<=n<13.
Output
输出进行了题目描述中赋值操作之后a对应的字符串。
请注意行尾输出换行。
Sample Input
7
Sample Output
China!
代码(C语言)
#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;
}
Time Limit: 1 Sec Memory Limit: 32 MB
Submit: 2354 Solved: 1292
Description
输入3个字符串,按从小到大的顺序输出。要求使用指针的方法进行处理。
Input
3行,每行一个用字符串。保证每个字符串的长度不超过20。
Output
按从小到大的顺序输出这3个字符串,每个字符串一行。
请注意行尾输出换行。
Sample Input
China
CLOCK
deal
Sample Output
CLOCK
China
deal
代码(C语言)
#include<stdio.h>
#include<string.h>
void swap1(char *s1,char *s2);
void swap2(char *r1,char *r2,char *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);
printf("\n");
return 0;
}
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);
}
Time Limit: 1 Sec Memory Limit: 32 MB
Submit: 1966 Solved: 1333
Description
输入10个整数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换。要求用3个函数实现,分别为输入10个数、进行处理、输出10个数。要求使用指针的方法进行处理。
Input
用空格隔开的10个整数。
Output
输出进行题目描述操作之后的10个整数,每个整数之后输出一个空格。
请注意行尾输出换行。
Sample Input
1 5 2 4 9 0 3 8 7 6
Sample Output
0 5 2 4 6 1 3 8 7 9
代码(C语言)
#include<stdio.h>
void inputs(int *p);
void outputs(int *p);
void sort(int *p);
int main(){
int a[10];
inputs(a);
output(a);
sort(a);
printf("\n");
return 0;
}
void inputs(int *p){
for(int i = 0; i < 10; i++){
scanf("%d",p+i);
}
}
void outputs(int *p){
for(int i = 0; i < 10; i++){
printf("%d",*(p+i));
}
}
void sort(int *p){
int max = 0,min = 0,t = 0,temp = 0;
max = *p;
min = *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;
}
版权所有:可定博客 © WNAG.COM.CN
本文标题:《Contest100000571 – 《算法笔记》2.7小节——C/C++快速入门->指针》
本文链接:https://cloud.tencent.com/developer/article/1616885
特别声明:除特别标注,本站文章均为原创,本站文章原则上禁止转载,如确实要转载,请电联:wangyeuuu@qq.com,尊重他人劳动成果,谢过~