C語言用指針函數(shù)尋找數(shù)組中的最大值與次大值
代碼示例:
#include <stdio.h>
// 函數(shù)用于找出數(shù)組中的最大值和次大值
void LargestTow(int a[], int n, int *pfirst, int *psecond) {
*pfirst = a[0];
*psecond = a[1];
if (*psecond > *pfirst) {
// 如果初始的次大值大于最大值,交換它們
int temp = *pfirst;
*pfirst = *psecond;
*psecond = temp;
}
for (int i = 2; i < n; i++) {
if (a[i] > *pfirst) {
// 如果當(dāng)前元素大于最大值,更新次大值為原來的最大值,最大值更新為當(dāng)前元素
*psecond = *pfirst;
*pfirst = a[i];
} else if (a[i] > *psecond) {
// 如果當(dāng)前元素大于次大值但小于最大值,更新次大值為當(dāng)前元素
*psecond = a[i];
}
}
}
int main() {
int n;
scanf("%d", &n);
int a[n];
for (int i = 0; i < n; i++) {
scanf("%d", &a[i]);
}
int max, second_max;
LargestTow(a, n, &max, &second_max);
printf("%d %d\n", max, second_max);
return 0;
}以下是按照先遍歷數(shù)組找出最大值,然后再次遍歷數(shù)組找出最小值的思路,使用 C 語言編寫的代碼來解決上述問題(找出n個整數(shù)中的最大值和次大值):
#include <stdio.h>
// 函數(shù)用于找出數(shù)組中的最大值和次大值
void LargestTow(int a[], int n, int *pfirst, int *psecond) {
int max_value = a[0];
int max_index = 0;
// 第一次遍歷數(shù)組,找出最大值及其索引
for (int i = 1; i < n; i++) {
if (a[i] > max_value) {
max_value = a[i];
max_index = i;
}
}
*pfirst = max_value;
// 將最大值所在位置的元素設(shè)為一個很小的值,避免它干擾找次大值
a[max_index] = -99999999;
int second_max_value = a[0];
// 第二次遍歷數(shù)組,找出次大值
for (int i = 1; i < n; i++) {
if (a[i] > second_max_value) {
second_max_value = a[i];
}
}
*psecond = second_max_value;
}
int main() {
int n;
scanf("%d", &n);
int a[n];
for (int i = 0; i < n; i++) {
scanf("%d", &a[i]);
}
int max, second_max;
LargestTow(a, n, &max, &second_max);
printf("%d %d\n", max, second_max);
return 0;
}題目描述
求n個整數(shù)中的最大值和次大值。要求定義一個函數(shù)LargestTow(),求數(shù)組a的最大值和次大值兩個值,分別存入形參指針pfirst和psecond所指存儲單元,函數(shù)原型如下:
void LargestTow(int a[],int n,int *pfirst,int *psecond)
{
/*數(shù)組a有n個元素,將數(shù)組中的最大值存入形參指針pfirst所指內(nèi)存單元,將數(shù)組中第二大的值存入形參指針psecond所指內(nèi)存單元。 */
}輸入描述
輸入有兩行,輸入第一行是一個整數(shù)n,1<n<=1000;第二行是n個整數(shù),由空格隔開。
輸出描述
輸入兩個整數(shù),表示數(shù)組中最大的兩個值。輸出占一行。
樣例輸入
5
6 3 4 9 8
樣例輸出
9 8
總結(jié)
到此這篇關(guān)于C語言用指針函數(shù)尋找數(shù)組中的最大值與次大值的文章就介紹到這了,更多相關(guān)C語言尋找數(shù)組最大值與次大值內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言靜態(tài)版通訊錄的設(shè)計(jì)與實(shí)現(xiàn)
靜態(tài)版通訊錄是一種簡單的通訊錄實(shí)現(xiàn)方式,通過定義固定的數(shù)組大小來存儲聯(lián)系人信息。該方法不支持動態(tài)增刪聯(lián)系人,但具有實(shí)現(xiàn)簡單、易于理解的優(yōu)點(diǎn)。在程序設(shè)計(jì)中,需注意數(shù)組邊界溢出等問題2023-04-04
C++深入淺出講解內(nèi)存四區(qū)與new關(guān)鍵字的使用
內(nèi)存四區(qū),一個非常重要的知識點(diǎn),搞懂了內(nèi)存四區(qū),才能更快的去搞懂指針。我們寫的C語言代碼,不夸張的說,都是直接或者間接的在操作內(nèi)存。C語言之所以能夠開發(fā)操作系統(tǒng),就是指針的存在,而指針說白了就是地址,內(nèi)存地址,指針變量說白了就是存儲地址的變量2022-05-05
C語言實(shí)現(xiàn)順序表的基本操作指南(注釋很詳細(xì))
線性表是最簡單的數(shù)據(jù)結(jié)構(gòu),而順序表又是最簡單的線性表,其基本思想是用一段地址連續(xù)的儲存單元依次存儲線性表的數(shù)據(jù)元素,下面這篇文章主要給大家介紹了關(guān)于C語言實(shí)現(xiàn)順序表的基本操作,需要的朋友可以參考下2021-10-10
C語言實(shí)現(xiàn)自動給QQ好友發(fā)窗口抖動
這篇文章主要介紹了C語言實(shí)現(xiàn)自動給QQ好友發(fā)窗口抖動,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-11-11

