1.题目:查找最小的k个元素(笔试题)
输入n个整数,输出其中最小的k个。
2.
输入n个整数,输出其中最小的k个。
例如输入1,2,3,4,5,6,7和8这8个数字,则最小的4个数字为1,2,3和4
1 #include<stdio.h>
2 int main()
3 {int n,i,*p,m,j,t;
4 printf("输入的数字个数: \n");
5 scanf("%d",&n);
6 int a[n];
7 p=a;
8 for(i=0;i<n;i++)
9 { scanf("%d",&a[i]); }
10
11 for(i=0;i<n;i++)
12 { printf("%d\n",a[i]);}
13 for(i=0;i<n-1;i++)
14 {
15 for(j=i+1;j<n-1;j++)
16 if (*(p+i)>*(p+j))
17 { m=*(p+i);
18 *(p+i)=*(p+j);
19 *(p+j)=m;
20 }
21 }
22 printf("输入最小的数字个数: ");
23 scanf("%d",&t);
24 for(i=0;i<t;i++)
25 { printf("%d\n",a[i]);}
26 return 0;
27 }
2.
题目:网友年龄
某君新认识一网友。
当问及年龄时,他的网友说:
“我的年龄是个2位数,我比儿子大27岁,
如果把我的年龄的两位数字交换位置,刚好就是我儿子的年龄”
请你计算:网友的年龄一共有多少种可能情况?
提示:30岁就是其中一种可能哦.
1 #include<stdio.h>
2 int main()
3 {
4 int m,n,i;
5 int a,b;
6 for(a=27;a<100;a++)
7 {
8 for(i=0;i<1;i++)
9 {
10 b=a-27;
11 m=(a%10)*10,n=a/10;
12 if ((m+n)==b)
13 {
14 printf("%d ",a);
15 }
16 }
17 }
18 return 0;
19 }