將兩個陣列作為輸入,嘗試合併或連接兩個陣列並將結果儲存在第三個陣列中。
合併兩個陣列的邏輯如下所示- p>
J=0,k=0 for(i=0;i<o;i++) {// merging two arrays if(a[j]<=b[k]){ c[i]=a[j]; j++; } else { c[i]=b[k]; k++; } }
#下面給出的程式展示如何用C 程式語言合併兩個陣列-
#include<stdio.h> #include<stdlib.h> int main(){ int a[10],b[10],c[20],m,n,o,i,j,k,temp; printf("Enter size of Array1</p><p>"); scanf("%d",&n); printf("Enter size of Array2</p><p>"); scanf("%d",&m); o=m+n; //size of third array printf("Enter Elements of Array1</p><p>"); for(i=0;i<n;i++){ scanf("%d",&a[i]); } printf("Enter Elements of Array2</p><p>"); for(i=0;i<m;i++){ scanf("%d",&b[i]); } //sorting first array for(i=0;i<n;i++){ for(j=0;j<n-1-i;j++){ if(a[j]>a[j+1]){ temp=a[j]; a[j]=a[j+1]; a[j+1]=temp; } } } //sorting second array for(i=0;i<m;i++){ for(j=0;j<m-1-i;j++){ if(b[j]>b[j+1]){ temp=b[j]; b[j]=b[j+1]; b[j+1]=temp; } } } printf("Elements of Array1</p><p>"); for(i=0;i<n;i++){ printf("a[%d]=%d</p><p>",i,a[i]); } printf("Elements of Array2</p><p>"); for(i=0;i<m;i++){ printf("b[%d]=%d</p><p>",i,b[i]); } j=0; k=0; for(i=0;i<o;i++){ // merging two arrays if(a[j]<=b[k]){ c[i]=a[j]; j++; } else{ c[i]=b[k]; k++; } } printf("Merged array is :</p><p>"); for(i=0;i<o;i++){ printf("c[%d]=%d</p><p>",i,c[i]); } }
當上述程式被執行時,它產生以下結果−
Enter Elements of Array1 1 2 3 4 Enter Elements of Array2 6 8 3 Elements of Array1 a[0]=1 a[1]=2 a[2]=3 a[3]=4 Elements of Array2 b[0]=3 b[1]=6 b[2]=8 Merged array is: c[0]=1 c[1]=2 c[2]=3 c[3]=3 c[4]=4 c[5]=6 c[6]=8
以上是如何在C語言中合併兩個陣列?的詳細內容。更多資訊請關注PHP中文網其他相關文章!