1.
题目内容:
方法二:
用指针方法,将一维数组int a[10] 中元素按从小到大顺序输出。
输入格式:
10个整数,空格隔开
输出格式:
排序后的10个数,逗号隔开
输入样例:
12 34 56 43 7 89 81 11 33 90
输出样例:
7,11,12,33,34,43,56,81,89,90
#include <stdio.h>
void sort(int *p,int n);
void sort(int *p,int n)
{
int i,j;
int temp=0;
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
if(p[j]>p[j+1])
{
temp=p[j];
p[j]=p[j+1];
p[j+1]=temp;
}
}
}
}
int main()
{
int i;
int a[10];
for(i=0;i<10;i++)
{
scanf("%d",&a[i]);
}
int *p=a;
sort(a,10);
for(i=0;i<10-1;i++)
{
printf("%d,",*(p++));
}
printf("%d\n",*p);
return 0;
}
2.查找数
题目内容:
用指针方法,在一个一维数组int a[10]的元素中,查找给定的数,若找到则输出该数,若没找到,输出No。
输入格式:
第一行:10个整数,空格隔开
第二行:要查找的数
输出格式:
找到的数orNo
输入样例:
11 22 43 56 78 90 76 4 2 10
43
输出样例:
43
输入样例:
1 8 3 4 5 6 2 1 7 9
10
输出样例:
No
方法一:
#include <stdio.h>
void find(int *p,int element,int n);
void find(int *p,int element,int n)
{
int i,flag=0;;
for(i=0;i<n;i++)
{
flag++;
p++;
if(element == *p)
{
printf("%d\n",*p);
break;
}
}
if(flag == n)
{
printf("No\n");
}
}
int main()
{
int i;
int a[10];
for(i=0;i<10;i++)
{
scanf("%d",&a[i]);
}
int *p=a;
int num;
scanf("%d",&num);
find(p,num,10);
return 0;
}
方法二:
#include <stdio.h>
void find(int *p,int element,int n);
void find(int *p,int element,int n)
{
int i,flag=0;;
for(i=0;i<n;i++)
{
flag++;
if(element == p[i])
{
printf("%d\n",p[i]);
break;
}
}
if(flag == n)
{
printf("No\n");
}
}
int main()
{
int i;
int a[10];
for(i=0;i<10;i++)
{
scanf("%d",&a[i]);
}
int *p=a;
int num;
scanf("%d",&num);
find(p,num,10);
return 0;
}
3.成绩排序
(10分)
题目内容:
从键盘输入3个同学4门课的成绩,将其按平均分从高到低排序输出。
输入格式:
输入3个同学4门课的成绩
输出格式:
按平均分从高到低排序输出
输入样例:
89 78 80 76 88 78 75 90 99 92 100 89
输出样例:
99,92,100,89
88,78,75,90
89,78,80,76
#include <stdio.h>
void average(int p[][6],int n);
void average(int p[][6],int n)
{
int i;
for(i=0;i<4;i++)
{
p[n][4]+=p[n][i];
}
p[n][5]=p[n][4]/4;
}
void Print(int p[][6],int n)
{
int max1=p[0][5];
int max2=p[1][5];
int max3=p[2][5];
int i;
if(max1>max2 && max1>max3)
{
if(max2>max3)
{
printf("%d,%d,%d,%d\n",p[0][0],p[0][1],p[0][2],p[0][3]);
printf("%d,%d,%d,%d\n",p[1][0],p[1][1],p[1][2],p[1][3]);
printf("%d,%d,%d,%d\n",p[2][0],p[2][1],p[2][2],p[2][3]);
}
else
{
printf("%d,%d,%d,%d\n",p[0][0],p[0][1],p[0][2],p[0][3]);
printf("%d,%d,%d,%d\n",p[2][0],p[2][1],p[2][2],p[2][3]);
printf("%d,%d,%d,%d\n",p[1][0],p[1][1],p[1][2],p[1][3]);
}
}
else if(max2>max1 && max2>max3)
{
if(max1>max3)
{
printf("%d,%d,%d,%d\n",p[1][0],p[1][1],p[1][2],p[1][3]);
printf("%d,%d,%d,%d\n",p[0][0],p[0][1],p[0][2],p[0][3]);
printf("%d,%d,%d,%d\n",p[2][0],p[2][1],p[2][2],p[2][3]);
}
else
{
printf("%d,%d,%d,%d\n",p[1][0],p[1][1],p[1][2],p[1][3]);
printf("%d,%d,%d,%d\n",p[2][0],p[2][1],p[2][2],p[2][3]);
printf("%d,%d,%d,%d\n",p[0][0],p[0][1],p[0][2],p[0][3]);
}
}
else if(max3>max1 && max3>max2)
{
if(max1>max2)
{
printf("%d,%d,%d,%d\n",p[2][0],p[2][1],p[2][2],p[2][3]);
printf("%d,%d,%d,%d\n",p[0][0],p[0][1],p[0][2],p[0][3]);
printf("%d,%d,%d,%d\n",p[1][0],p[1][1],p[1][2],p[1][3]);
}
else
{
printf("%d,%d,%d,%d\n",p[2][0],p[2][1],p[2][2],p[2][3]);
printf("%d,%d,%d,%d\n",p[1][0],p[1][1],p[1][2],p[1][3]);
printf("%d,%d,%d,%d\n",p[0][0],p[0][1],p[0][2],p[0][3]);
}
}
}
int main()
{
int i,j;
int a[3][6]={0};
for(i=0;i<3;i++)
{
for(j=0;j<4;j++)
{
scanf("%d",&a[i][j]);
}
average(a,i);
}
Print(a,3);
return 0;
}