#include <stdio.h>
main()
{
char s[80],c
int j,k
printf("\nEnter a string: ")
gets(s)
printf("\nEnter a character: ")
c=getchar( )
for(j=k=0s[j]!= '\0'j++)
if(s[j]!=c)
s[k++]=s[j]
s[k]= '\0'
printf("\n%s\n",s)
system("pause")
}
扩展资料
自定义函数代码如下
function delarrayval2($arr,$v){
$keyarr = array_keys($arr, $v)
if(count($keyarr)){
foreach ($keyarr as $key) {
unset($arr[$key])
}
}
return $arr
}
#include\x0d\x0atypedef struct Node{\x0d\x0aint a,b\x0d\x0a}node\x0d\x0anode c[100]\x0d\x0aint n\x0d\x0avoid print(){\x0d\x0a int i\x0d\x0a printf("\n当前数据:\n")\x0d\x0a for(i=1i 回答于 2022-12-11方法:
删除就是将其下标所在位置的中的内容置为空(也就是0),然后从此位置开始,后面的内容前移,再把最后那个位置的置为空(就是0)。
前移无非就是 类似 arr[ i - 1] = arr[ i ] 这个意思。
当可以确认数组中存放的都是整数,你可以将这个元素置为-1表示删除。增加就是先检查你的数组中有没有-1的元素,如果有,就设置为你的值。如果全部都满了,就开一个更大的数组,把数据拷贝过去。把相应位后面的一次前移一位,就是实现了删除操作,可以用个for循环就可以实现了。
数组的内存分配:变量在内存中是从大到小寻址的(内存中以字节为单位),比如00000000 00000000 00000000 00001010在内存中,00001010的地址是最小的;而数组则有些不同,数组的元素自然的从上往下排列 存储,整个数组的地址为首元素的地址。 (但是组成元素的字节还是按从大到小)。