선택 정렬을 위한 C 프로그램
선택 정렬은 배열에서 가장 작은 숫자를 찾아 첫 번째 위치에 배치하는 방식으로 작동하는 공격적인 알고리즘입니다. 탐색할 다음 배열은 가장 작은 숫자가 있는 다음 인덱스에서 시작됩니다.
이 개념을 더 명확하게 설명하기 위해 예를 들어 보겠습니다.
{6, 3, 8, 12, 9} 배열이 있고 이 배열의 가장 작은 요소는 3입니다. 따라서 우리는 첫 번째 위치에 3을 배치하고 그 이후 배열은 {3, 6, 8, 12, 9} 처럼 보일 것입니다. 이제 우리는 가장 작은 숫자를 다시 찾을 것입니다. 그러나 이번에는 3이 그 자리에 있기 때문에 검색에서 고려하지 않을 것입니다. 다음으로 가장 작은 요소인 6을 찾고 두 번째 위치에 6이 포함된 배열을 만든 다음 배열이 정렬될 때까지 배열에서 다시 검색합니다.
선택 정렬 알고리즘 작동 방식 -
선택 정렬 알고리즘은 다음 단계를 따릅니다.
배열 {20, 12, 23, 55,21}
-
배열의 첫 번째 요소를 최소값으로 설정합니다. .
Min value = 20
-
최소값을 다음 요소와 비교하여 최소값보다 작으면 해당 요소를 최소값으로 지정합니다. 배열이 끝날 때까지 이 작업을 수행합니다.
는 12:20 > 12와 비교되고, 최소값 = 12
는 23:12 은 55:12
21: 12
-
과 비교하면 최소값을 배열의 첫 번째 위치(인덱스 0)에 넣습니다.
Array = {12, 20,23, 55, 21}
-
다음 반복에서는 정렬되지 않은 첫 번째 요소부터 정렬을 시작합니다.
Array = {12, 20,23, 55, 21}
20부터 검색을 시작하여 다음으로 최소값을 갖는 요소를 배치합니다.
반복 2:
최소값 = 20
23 대비: 20
55 대비: 20
21 대비: 20
최소값은 변경되지 않고 유지됩니다.
array = {12, 20,23, 55, 21}
반복 3:
최소값 = 23.
55 대비: 23
21 대비: 23 > 21, 최소값 = 21
인덱스로 이동한 최소값 = 2
Array = {12, 20, 21, 55, 23}
반복 4:
최소 = 55
23과 비교: 23
최소 인덱스 3으로 이동 배열 = { 12 , 20 , 21 , 23 , 55 }
Example
#include <stdio.h> int main() { int arr[10]={6,12,0,18,11,99,55,45,34,2}; int n=10; int i, j, position, swap; for (i = 0; i < (n - 1); i++) { position = i; for (j = i + 1; j < n; j++) { if (arr[position] > arr[j]) position = j; } if (position != i) { swap = arr[i]; arr[i] = arr[position]; arr[position] = swap; } } for (i = 0; i < n; i++) printf("%d\t", arr[i]); return 0; }
Output
0 2 6 11 12 18 34 45 55 99
위 내용은 선택 정렬을 위한 C 프로그램의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











아래에는 로마 숫자를 십진수로 변환하는 C 언어 알고리즘이 나와 있습니다. 알고리즘 1단계 - 시작 2단계 - 런타임에 로마 숫자 읽기 3단계 - 길이: = strlen(roman) 4단계 - i=0에서 길이-1까지 단계 4.1-switch(roman[i]) 4.1.1단계-case'm': &nbs

사전식 문자열 비교는 문자열이 사전 순서로 비교된다는 것을 의미합니다. 예를 들어 'apple'과 'appeal'이라는 두 개의 문자열이 있는 경우 'app'의 처음 세 문자가 동일하므로 첫 번째 문자열이 마지막에 옵니다. 그러면 첫 번째 문자열의 문자는 'l'이고 두 번째 문자열의 네 번째 문자는 'e'입니다. 'e'는 'l'보다 짧기 때문에 사전순으로 정렬하면 e가 먼저 나옵니다. 문자열은 정렬되기 전에 사전순으로 비교됩니다. 이 기사에서는 C++를 사용하여 두 문자열을 사전순으로 비교하는 다양한 기술을 살펴보겠습니다. C++ 문자열에서 Compare() 함수 사용하기 C++string 개체에는 Compare() 함수가 있습니다.

쌍곡선 함수는 원 대신 쌍곡선을 사용하여 정의되며 일반 삼각 함수와 동일합니다. 제공된 각도(라디안)에서 쌍곡사인 함수의 비율 매개변수를 반환합니다. 그러나 반대로 하십시오. 즉, 반대로 하십시오. 쌍곡선 사인으로부터 각도를 계산하려면 쌍곡선 역사인 연산과 같은 역쌍곡선 삼각법 연산이 필요합니다. 이 과정에서는 라디안 단위의 쌍곡선 사인 값을 사용하여 각도를 계산하기 위해 C++에서 쌍곡선 역사인(asinh) 함수를 사용하는 방법을 보여줍니다. 쌍곡선 아크사인 연산은 다음 공식 -$$\mathrm{sinh^{-1}x\:=\:In(x\:+\:\sqrt{x^2\:+\:1})}을 따릅니다. 여기서\:In\:은\:자연 로그\:(log_e\:k)

연결된 목록은 동적 메모리 할당을 사용합니다. 즉, 그에 따라 메모리가 늘어나고 줄어듭니다. 이는 노드 모음으로 정의됩니다. 여기서 노드는 데이터와 링크라는 두 부분으로 구성됩니다. 데이터, 링크, 연결리스트는 다음과 같이 표현됩니다. - 연결리스트의 종류 연결리스트에는 다음과 같은 4가지 종류가 있습니다. - 단일 연결리스트 / 단일 연결리스트 이중 / 이중 연결리스트 원형 단일 연결리스트 순환 이중 연결리스트 연결된 목록의 길이를 찾는 재귀 메서드 논리는 -intlength(node *temp){ if(temp==NULL) returnl{&n;

맵은 각 요소가 두 값, 즉 키 값과 맵 값의 쌍인 C++의 특수한 유형의 컨테이너입니다. 키 값은 각 항목을 인덱싱하는 데 사용되며 매핑된 값은 키와 연결된 값입니다. 매핑된 값이 고유한지 여부에 관계없이 키는 항상 고유합니다. C++에서 맵 요소를 인쇄하려면 반복자를 사용해야 합니다. 항목 집합의 요소는 반복자 개체로 표시됩니다. 반복자는 주로 배열 및 기타 유형의 컨테이너(예: 벡터)와 함께 사용되며 특정 범위 내의 특정 요소를 식별하는 데 사용할 수 있는 특정 작업 집합을 가지고 있습니다. 반복자는 범위나 컨테이너에 있는 다양한 요소를 참조하기 위해 증가하거나 감소할 수 있습니다. 반복자는 범위에 있는 특정 요소의 메모리 위치를 가리킵니다. 반복자를 사용하여 C++에서 지도 인쇄하기 먼저, 정의하는 방법을 살펴보겠습니다.

이름 바꾸기 기능은 파일이나 디렉토리를 이전 이름에서 새 이름으로 변경합니다. 이 작업은 이동 작업과 유사합니다. 따라서 이 이름 바꾸기 기능을 사용하여 파일을 이동할 수도 있습니다. 이 함수는 stdio.h 라이브러리 헤더 파일에 있습니다. rename 함수의 구문은 다음과 같습니다. intrename(constchar*oldname,constchar*newname); rename() 함수의 함수는 두 개의 매개변수를 허용합니다. 하나는 oldname이고 다른 하나는 newname입니다. 두 매개변수는 모두 파일의 이전 이름과 새 이름을 정의하는 상수 문자에 대한 포인터입니다. 파일 이름이 성공적으로 변경되면 0을 반환하고, 그렇지 않으면 0이 아닌 정수를 반환합니다. 이름 바꾸기 작업 중

현대 과학은 복수의 개념에 크게 의존하고 있는데, 이는 17세기 초 Girolamo Cardano가 처음으로 확립한 것으로, 그는 16세기에 이를 도입했습니다. 복소수의 공식은 a+ib입니다. 여기서 a는 html 코드이고 b는 실수입니다. 복소수는 실수부 <a>와 허수부(<ib>)의 두 부분으로 구성됩니다. i 또는 iota의 값은 √-1입니다. C++의 복수형 클래스는 복소수를 나타내는 데 사용되는 클래스입니다. C++의 복소수 클래스는 여러 복소수 연산을 표현하고 제어할 수 있습니다. 복수의 숫자 표시를 어떻게 표현하고 제어하는지 살펴보겠습니다. imag() 멤버 함수 위에서 언급했듯이 복소수는 실수부와 허수부로 구성됩니다. 실제 부분을 표시하려면 real()을 사용합니다.

문자열이나 문자를 사용하는 것은 일부 논리 프로그래밍 문제를 해결할 때 때때로 매우 유용합니다. 문자열은 문자 모음으로, ASCII 값의 기호를 보유하는 데 사용되는 1바이트 데이터 유형입니다. 기호는 영문자, 숫자, 특수문자가 될 수 있습니다. 이번 글에서는 C++를 이용하여 문자가 영문자인지 알파벳인지 확인하는 방법을 알아보겠습니다. isalpha() 함수 확인 숫자가 문자인지 확인하려면 ctype.h 헤더 파일에서 isalpha() 함수를 사용할 수 있습니다. 문자를 입력으로 받아 알파벳이면 true를 반환하고, 그렇지 않으면 false를 반환합니다. 이 함수의 사용법을 이해하기 위해 다음 C++ 구현을 살펴보겠습니다. 예제의 중국어 번역은 다음과 같습니다.
