十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
如果你只是删掉为k的值,然后输入的话,只要一个for循环就够了,把不等于k的值直接输出就行,不用再存入数组里了,如:
站在用户的角度思考问题,与客户深入沟通,找到和龙网站设计与和龙网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:成都网站设计、网站制作、企业官网、英文网站、手机端网站、网站推广、空间域名、网页空间、企业邮箱。业务覆盖和龙地区。
#includestdio.h
void
main()
{
int
n,k,x[100000];
int
i,flag=0;
scanf("%d",n);
for(i=0;in;i++)
scanf("%d",x[i]);
scanf("%d",k);
for(i=0;in;i++)
if(x[i]!=k)
{
if(flag==0)
//(让第一个输出前不加空格)
{
printf("%d",x[i]);
flag=1;
}
else
printf("
%d",x[i]);
}
printf("\n");
}
一维 二维都可以
删除其后相同元素并前置
以前做的别的没有了
#includestdio.h
#define M 2
#define N 5
void main()
{
int c[M][N];
int i,j,m,n;
printf("请输入%d行%d列矩阵\n",M,N);
for(i=0;iM;i++)
{
for(j=0;jN;j++)
scanf("%d",c[i][j]);
}
printf("C[M][N]:\n");
for(i=0;iM;i++)
{
for(j=0;jN;j++)
printf("%8d",c[i][j]);
putchar('\n');
}
for(m=0;mM;m++)
{
for(n=0;nN;n++)
{
for(i=0;iM;i++)
{
for(j=0;jN;j++)
{
if(m==in==j);
else
if(c[m][n]==c[i][j])
{
c[i][j]=0;
}
}
}
}
}
for(i=0;iM;i++)
{
for(m=0;mN;m++)
for(j=0;jN-1;j++)
if(c[i][j]==0)
{
c[i][j]=c[i][j+1];
c[i][j+1]=0;
}
}
printf("C[M][N]x:\n");
for(i=0;iM;i++)
{
for(j=0;jN;j++)
printf("%8d",c[i][j]);
putchar('\n');
}
}
在JAVA中如何从数组中删除一个元素的程序如下:
package org.usc.action;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
public class Test {
public static void main(String[] args) {
String[] str={"张三","李四","王五","宋六","赵七","朱八","何九","田十"};
ListString list=Arrays.asList(str);//将数组转换为list集合
if(list.contains("张三"))
{//加入集合中包含这个元素
///这个时候我们直接移除会报错,所以我们要转换为Arraylist
//list.remove("张三");
ListString arrayList=new ArrayListString(list);//转换为ArrayLsit调用相关的remove方法
arrayList.remove("张三");
for(String str1:arrayList ){
System.out.print(str1+",");}
}}
部分解释:
1、remove这些method时出现java.lang.UnsupportedOperationException异常。
2、这是由于Arrays.asList() 返回java.util.Arrays$ArrayList, 而不是ArrayList。Arrays$ArrayList和ArrayList都是继承AbstractList, remove,add等method在AbstractList中是默认throw UnsupportedOperationException而且不作任何操作。
3、ArrayList override这些method来对list进行操作,但是Arrays$ArrayList没有override remove(),add()等, 所以throw UnsupportedOperationException。
扩展资料:
因为Java没有结构,数组和串都是对象,所以不需要指针。Java能够自动处理对象的引用和间接引用,实现自动的无用单元收集。
Java允许扩展编译时检查潜在类型不匹配问题的功能。Java要求显式的方法声明,它不支持C风格的隐式声明。
异常处理是Java中使得程序更稳健的另一个特征。异常是某种类似于错误的异常条件出现的信号。使用try/catch/finally语句,程序员可以找到出错的处理代码,这就简化了出错处理和恢复的任务。
可以自己写个函数,在源字符串中查找目标字符串并删除,后续字符依次前移。
#includestdio.h
void f(char a[])
{
int n,i,j,k;
i = 0;
while(a[i] != '\0')
i++;
n = i; // 字符长度
for(i = 1;in;i++)
{
for(j=0;ji;j++)
{
if(a[i] == a[j])
{
for(k=i;kn-1;k++)
a[k] = a[k+1];
a[k] = '\0';
i--;
n--;
}
}
}
printf("%s\t",a);
printf("%d\n",n);
}
void main()
{
char a[100];
scanf("%s",a);
f(a);
}
如下int del_zero(int *p,int n);为你需要的函数,下面附带测试程序!
不明白就追问吧!
#includestdio.h
int del_zero(int *p,int n);
int main(void)
{
int i,n,test[128];
printf("请输入测试数组元素的个数n...\n");
scanf("%d",n);
printf("请输入%d个数组元素\n",n);
for(i=0;in;i++)
scanf("%d",test[i]);
printf("\n输入的数据元素为:\n");
for(i=0;in;i++)
printf("%d ",test[i]);
n=del_zero(test,n);
printf("\n删除0元素后的数组长度=%d,剩余元素为:",n);
for(i=0;in;i++)
printf("%d ",test[i]);
return 0;
}
int del_zero(int *p,int n)
{
int i,j,temp,len=n;
for(i=0;ilen;i++){
if(p[i]==0){
for(j=i;jlen;j++){
p[j]=p[j+1];
}
len--;
}
}
return len;
}