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

c語言數組共用

發布時間: 2022-03-12 03:47:22

Ⅰ 在c語言數組中&怎麼用

真是沒轍...實在就多分配點空間...鏈表是動態的,如果用c++。把動態分配放到類裡面,就給你一個介面,你是不是也認為那是動態的呢??c與vb不能比...vb有幾個是弄內存的?

Ⅱ C語言數組怎麼調用

有好幾種方法,我稍微說一下,你回去找書看一看:
通過數組首地址 指針 帶下標的指針引用一維數組元素。
引用一維數組中的某一個元素的方法:
* :求當前地址的內容 & :求當前內容的地址
1 a【i】
2 *&a【i】 //*在定義語句時代表定義一個指針變數,當在執行語句部分時代表間址運算符,引用一個指針變數指向的地址的內容。&叫求地址運算符,求當前內容的地址。所以*和&就像乘號和除號一樣,互相抵消了。
3 *(a+i):在數組名的地址上,加上i個存儲單元。代表第(i+1)個元素,用間址運算符引用它,即等價於a[i]
4 當(p=a;||p=&a【0】) 則 *(p+i)等價於a[i]
5 當(p=a;||p=&a[0]) 則 p[i] 等價於 a[i] //方括弧不僅表示數組元素的記方括弧不僅表示數組元素的記方括弧不僅表示數組元素的記方括弧不僅表示數組元素的記號號號號,也是一種運算符也是一種運算符也是一種運算符也是一種運算符.
總結:引用一維數組元素 a[i] 的四種方法: a[i] *(a+i) 若p=a, 則 p[i] *(p+i) 表示a[i]的地址的方法:&a[i] a+i p+i 都表示當前數組第i個元素的地址。
http://wenku..com/view/46092a66783e0912a2162a27.html這是引用的網頁,你可以自己去看看!

Ⅲ 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語言怎麼連接兩個一維數組

你可以考慮用指針配合動態分配內存來做。首先確認兩個一維數組的總長度,然後下面是一個例子代碼:
int *a = malloc(n*sizeof(int));
將第一個和第二個數組順序加到a指針就好了。

Ⅳ 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語言共用體裡面的數組

這里共用體用char[0]存儲一個整數的低八位,這里用char[1]存儲一個整數的高八位。當高八位的最後一位為1時,相當於十進制的256。加13後是269。

Ⅶ 同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語言 數組共享式

有一個已排好序(從大到小)的數組有5個元素,從鍵盤輸入一個數,要求按原排序的規律將它插入到數組中
#include
void main()
{
int i,x,j;
int a[6]={1,5,10,15,20};
scanf("%d",&x);
for(i=0;i<5;i++)
if(x<a[i])
{
j=i; /*當這個數比當前數小時,用j記住當前位置,即j=i,中斷循環。比當前數大時繼續下一個(小應當在左側,大則在右側) */
break;
}
for(i=5;i>=j;i--)
a[i+1]=a[i]; /*將位置j以後的數據都向後移一位*/
a[i+1]=x; /* 把要插入的數x放到a[i]中,因為i--後 i 比實際要插入的位置少1,所以真正插入的位置應該i+1*/

for(i=0;i<=5;i++) /*這時一共有6個數*/
{
printf("%d ",a[i]);
}
}

Ⅸ 怎麼用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語言中共用體怎麼申請數組

typedef union {
UINT32 Aa;
struct {
UINT16 Bb;
UINT16 Cc;
} tt;
} pos;//這句typedef給union{...}定義了別名pos;pos是個類型 應該pos m_pos[xxx];
//去掉typedef到可以直接union{...}pos[xxx];
pos m_pos[100];
m_pos[0].tt.Bb==0;