题目四:寻找数组中第二大的数要求:给定一个整数数组,编写一个C语言函数,找出并返回数组中的第二大数。```cint findSecondLargest(int arr[]
在C语言中,要找出数组中的第二大数,可以按照以下步骤进行: 初始化一个足够大的数组,并填充测试数据: c int arr[] = {12, 35, 1, 10, 34, 1}; int n = sizeof(arr) / sizeof(arr[0]); 遍历数组,找出最大的数并存储: c int max1 = arr[0]; for (int i = 1; i < n; i+...
设置两个变量max1和max2,用来保存最大数和第二大数,然后将数组剩余的数依次与这两个数比较,如果这个数a比max1大,则先将max1赋给max2,使原先最大的数成为第二大的数,再将这个数a赋给max1,如果这个数a比max1小但比max2大,则将这个数a赋值给max2,依次类推,直到数组中的数都比较完。 c语言代码: 1#i...
else if(a[i]>max2)max2=a[i];printf("第二大的数是 %d\n",max2);getch();return 0;}
我分析下思路:2轮冒泡,可以找出第二大数。2轮循环。也可以找出第二大的。你要到公司面试,要讲效率的话。可以看看我写的下面这个代码 这是用快速排序,夹逼原则来锁定要找的第K大的元素 void swape(int *p1,int *p2){ int temp;temp=*p1;p1=*p2;p2=temp;} int searchPosition(int a[10...
{ if(num[j]>num[i]) { temp=num[j]; num[j]=num[i]; num[i]=temp; } } printf("第二大的数是:%d\n",num[1]); return 0;}
("第二大数为%d\n", FindSecondMax(array, 4)); return 0; } /*** * * author : RISE_AND_GRIND@163.com * date : 2024/04/07 * function : 找出一个整数数组中,第二大的数 * note : None * * ***/ int FindSecondMax(int *ptr, int n) { int max1 = 0...
//c语言求1到1000之间的第二大完数#include <stdio.h>int main(){ int i,j,cnt=0; int a[100]; for(i=2;i<=1000;i++) { int sum = 0; for(j=1;j
1、排序;//直接了当,适用范围广 2、求出最大的,再比较剩下的两个,求较大的数。
void main(){ int a[10],i,j,m;printf("please input 10 nembers:\n");for(i=0;i<10;i++)scanf("%d",&a[i]);for(i=0;i<9;i++)for(j=i+1;j<10;j++){ if(a[i]