當前位置:首頁 » 編程語言 » c語言u8數組合成
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

c語言u8數組合成

發布時間: 2022-08-23 04:30:44

c語言中數組的合並

//兩個數組合並,參考代碼:
#include "stdio.h"
int d=0; //用於記錄數組c的大小,和數組c的輸出類的一些操作
void main()
{
int a[50],b[50],c[100];
int i,j,k; //i表示a數組的大小 j表示b數組的大小 k用於數組的輸出
printf("數組a的輸入,輸入一個數,表明你要輸入多少個數到數組a中\n");
scanf("%d",&i);
for(k=0;k<i;k++)
scanf("%d",&a[k]);
printf("數組b的輸入,輸入一個數,表明你要輸入多少個數到數組b中\n");
scanf("%d",&j);
for(k=0;k<j;k++)
scanf("%d",&b[k]);
void px(int *p,int n); //聲明 排序 冒泡法
px(a,i); //調用
px(b,j); //調用
void prin(int *p,int n); //聲明 數組的輸出函數
prin(a,i);
prin(b,j);
void hb(int *o,int *p,int *q,int m,int n); //聲明 兩個數組的合並函數 前提:這倆個數組必須是排好序的
hb(c,a,b,i,j);
prin(c,d);
}

void px(int *p,int n) //自定義函數 排序 冒泡法
{int i,j,t,leap;
for(i=0;i<n-1;i++) //外層循環n-1次,一次循環沉澱一個數
{
leap=0; //leap作為標記,是否兩數相換
for(j=0;j<n-i-1;j++) //內循環n-i-1次
{
if(p[j]>p[j+1]) //比較兩個數
{
t=p[j];
p[j]=p[j+1];
p[j+1]=t; //來兩個數交換
leap=1; //交換了,標記leap=1
}
}
if(leap==0) break; //經歷了一個內for循環,leap==0的話,表明排序成功了,不需要接下來在排序了。
}
}

void prin(int *p,int n) //自定義函數 數組輸出函數
{
int k,sum=0;
for(k=0;k<n;k++)
{
printf("%d ",p[k]);
sum++;
if(sum%10==0) printf("\n");
}
printf("\n");
}

void hb(int *o,int *p,int *q,int m,int n) //m為p指向數組的大小 n為q指向數組的大小 指針o指向合並的數組
{
int i=0,j=0,k; //i為p指向數組的大小 j為q指向數組的大小
while(1)
{
if(p[i]<q[j])
{
o[d]=p[i];
i++;
d++;
}
else
{
o[d]=q[j];
j++;
d++;
}
if(i==m||j==n) break;
}
if(i==m)
{
for(k=j;k<n;k++)
{
o[d]=q[k];
d++;
}
}
if(j==n)
{
for(k=i;k<m;k++)
{
o[d]=p[k];
d++;
}
}
}

Ⅱ 怎麼用c語言將兩個數組並起來

看代碼,寫了幾種數組的合並:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
voidcharacter()
{
charc1[]={'H','e','l','l','o'};
charc2[]={'','w','o','r','l','d','!'};
intk=0;
charnew_c[100];
for(inti=0;i<sizeof(c1);i++)//注意是sizeof()
new_c[k++]=c1[i];
for(i=0;i<sizeof(c2);i++)
new_c[k++]=c2[i];
new_c[k]='';
puts(new_c);

}
voidstring()
{
chars1[]={"hello,"};
chars2[]={"c語言!"};
intk=0;
charnew_s[100];
for(inti=0;i<strlen(s1);i++)//注意是strlen()
new_s[k++]=s1[i];
for(i=0;i<strlen(s2);i++)
new_s[k++]=s2[i];
new_s[k]='';
puts(new_s);
}
voidnumber()
{
intnum1[]={1,2,3},*p1=num1;
intnum2[]={4,5,6,''};//整型數組,字元數組是沒有結束符號,自己加入『』
intnew_num[100];
intk=0;
for(inti=0;i<sizeof(num1)/sizeof(int);i++)
{
new_num[k++]=*(p1++);
}
for(i=0;num2[i]!=0;i++)
{
new_num[k++]=num2[i];
}
new_num[k]='';
for(i=0;new_num[i]!=0;i++)
{
printf("%d",new_num[i]);
}
puts("");

}
voidmain()
{
character();//字元數組的合並
string();//字元串的合並
number();//整型數組的合並,做法是一樣的

}

運行截圖:

Ⅲ 如何用C語言編程將兩個有序數組a,b合並成一個數組c

就以你的例子來寫,可適當修改為更普遍的

演算法核心代碼為:

int i = j = k = 0;
//循環比較,將小的插入到C數組中

while ( i < 3 && j < 3) {
if (a [i] < b [j]) c[k++] = a[i++];
else c[k++] = b[j++];

}
//處理其中一個數組剩下

while (i < 3) c[k++] = a[i++];
while( j < 3) c[k++] = b[j++];
或許有更好的實現,你自己在想想吧!

Ⅳ 請問如何使用C語言把兩個數組合並在一個數組里

代碼文本:

#include "stdio.h"

int input(int *p,int n){

char i,ch;

for(i=0;i<n;i++){

if((ch=getchar())==' ')

break;

else if(ch>='0' && ch<='9')

ungetc(ch,stdin);

scanf("%d",p+i);

}

return i;

}

int main(int argc,char *argv[]){

int a[21],b[10],i,j,k;

printf("Input array a... ");

i=input(a,10);

printf("and input array b... ");

j=input(b,10);

for(k=0;k<j;a[i++]=b[k++]);

for(j=0;j<i;printf("%d ",a[j++]));

putchar(' ');

return 0;

}

Ⅳ C語言編程 數組合並

#include<stdio.h>
int main()
{
int aLength;
scanf("%d",&aLength);
int a[aLength];
int i,j=0;
for(i=0;i<aLength;i++)
{
scanf("%d",a+i);
}
int bLength;
scanf("%d",&bLength);
int b[bLength];
for(i=0;i<bLength;i++)
{
scanf("%d",b+i);
}
int allLength=aLength+bLength;
int c[allLength];
for(i=0;i<aLength;i++)
{
c[i]=a[i];
}
for(i=aLength;i<allLength;i++)
{
c[i]=b[j];
j++;
}
for(i=0;i<allLength;i++)
{
printf("%d ",c[i]);
}
return 0;
}

Ⅵ 同C語言合並兩個數組

合並數組的操作,具體演算法依賴於合並的規則。

其通用流程如下:

1 建立一個足夠容納兩個數組所有元素的目標數組。如果規則規定將一個數組合並到另一個之中,那麼需要保證目標數組有可以容納兩個數組的空間,否則會出現越界。

2 遍歷其中一個數組,並賦值到目標數組中。如果是一個數組合並到另一個,那麼此步可以省略;

3 遍歷另一個數組,按照規則插入到目標數組中。

在不同規則下,合並演算法會有差異,如將長為lb的B數組附加到長為la的A數組結尾的操作,可以寫作

inti;
for(i=0;i<lb;i++)
A[la+i]=B[i];

而將長度均為l的數組A,B,交替合並到C中,可以寫作

inti;
for(i=0;i<l;i++)
{
C[i*2]=A[i];
C[i*2+1]=B[i];
}

不管是何種方式,合並的本質就是,把A和B的每個元素,賦值到目標數組的對應位置上即可。

Ⅶ c語言怎麼合並兩個數組

int main() {
char a[] = "123456";
char b[] = "abcde";
int buflen = strlen(a) + strlen(b);
char *p = (char*)malloc(buflen + 1);
memset(p, 0, buflen);
printf("%d\n", buflen);
strcpy(p, a);
strcat(p, b);
printf("%s\n", p);
free(p);
}
C的數組在創建後不可變得,因此數組合並的思想就是把數組塞到一個足夠大的空間里形成新數組。
上面的函數是比較簡單的合並方法

Ⅷ C語言如何把三個數組合成一個數組 如a[]={1,2,3}b[]={4,5,6}c[]={7,8,9} 結:d[]={1,2,3,4,5,6,7,8,9,}

設置一個字元串buffer,把三個數組分別循環一遍,放進buffer,用逗號隔開,然後再轉化成一個數組!

Ⅸ 怎樣在C語言中實現兩個數組的合並

把兩個數組分別合到一個數組裡面啊.
那個數組的長度為 兩個數組的長度的和

Ⅹ C語言數組字元串合成

//將兩個字元串合成一個字元串,在括弧中填入適當的語句,編譯
運行出正確的結果。
#include
<stdio.h>
#include<string.h>
void
main()
{
char
s1[20],s2[30],s3[50];
int
i,j,lengths1,lengths2;
printf("string1:");
gets(s1);
printf("string2:");
scanf("%s\n",s2);
lengths1=strlen(s1);
lengths2=strlen(s2);
for(i=0;i<lengths1;i++)
s3[i]=s1[i];
for(j=lengths1;j<lengths1+lengths2;j++)
s3[j]=s2[j-lengths1];
s3[j]='\0';//沒有這一步很可能就出現
段錯誤

printf("append
string
3:%s\n",s3);
}
//如
運行:
string1:abc//
string2:def//
結果:append
string3:abcdef幫忙修改下