C语言中关于数组的编程题~

输入10个整数,不排序直接查找并输出所有重复的数字。#include<stdio.h>voidmain(){inti,j,a[10];for(i=0;i<10;i++)s... 输入10个整数,不排序直接查找并输出所有重复的数字。
#include<stdio.h>
void main()
{
int i,j,a[10];
for(i=0;i<10;i++)
scanf("%d",&a[i]);
for(i=0;i<10;i++)
for(j=i+1;j<10;j++)
if (a[i]==a[j])
printf("%d",a[i]);
else continue;
}
按上面这么输的话会提示我misplace else\continue in function main,如果把else continue;去掉则语法正确,想问一下这个错误是什么原因引起的?
另外,按我这样编写的话,输出答案的数字会有重复,比如说我输入2234234564,答案是2223444,我该如何去掉重复的数字呢?(答案应该是234)
可以再说的清楚点吗?怎么把那些数放入另一个数组?又怎么进行比较?我的C比较烂啊。。。。。。
展开
 我来答
feng2006fei
2008-05-19
知道答主
回答量:20
采纳率:0%
帮助的人:0
展开全部
提点我的看法:
按你程序的意思 else continue这语句是多余的
把这删除之后你的程序运行结果将还是2223444

要得到答案234
你可以选择使用两个数组或者是一个二维数组
2234234564
0100111001 //标志数组
定义一个同样长度的一个整型数组 初值赋值为0 按你的方法如果执行a[i]==a[j]
你就把那个相同的位设置为1
根据标志数组中0和1的值就可以获得 重复数字 和 去掉重复数字后的数组了

for(i = 0 ; i< 10; i++ ){
if( b[i] == 0 )printf("%d",a[i]);//去掉重复数字后的数字
}
for(j= 0 ; j <10 ; j++ ){
if( b[j] == 1 )printf("%d",a[j]);//重复数字
}

不知道这样的回答你满意不!可以尝试一下哦
悉己n
2008-05-15 · TA获得超过759个赞
知道小有建树答主
回答量:684
采纳率:100%
帮助的人:560万
展开全部
1.第一个错误是因为你的if else结构没有用{ } 包起来,导致只有if被放到for 循环里了。所以以后要注意,尽量不要偷懒。。

2.比较直接的解决办法是再找一个数组,存储已经 printf过的数,然后每次printf 前检查一下,是否已经存在了,存在就不printf
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友21b6e13fe
2008-05-15 · 超过46用户采纳过TA的回答
知道答主
回答量:254
采纳率:0%
帮助的人:162万
展开全部
我这里else continue;没有报错嘛,我用的是VC++6.0,另外你这个如果说要去掉重复数字的话,我认为可以把找出的数放入另外一个数组,再查找的时候可以与新数组中的数比较,如果==,就continue。
另外你的for(i=0;i<10;i++)
for(j=i+1;j<10;j++) 也要改下,当i=9的时候j=10,会产生越界。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
义昀欣ek
2008-05-15 · TA获得超过3298个赞
知道小有建树答主
回答量:6776
采纳率:0%
帮助的人:2171万
展开全部
第一个问题。我在unix下用cc编译没有错误。不知道楼主用的什么环境?按说楼主的写法只是风格不良,并没有错误。

第二个问题,简单的办法是,楼主把你搜索到的结果输出时进行判断。第一个数直接输出,第二个数与第一个数判断不等后再输出,第三个数与前两个数判断不等后再输出。。。以此类推。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
_野香蕉_
2008-05-15 · TA获得超过3305个赞
知道大有可为答主
回答量:3567
采纳率:50%
帮助的人:1191万
展开全部

if。。。
else 。。
用大括号括起来就对了。

for把 他后面第一个 ; 当作结束点了。

有的编译器for后面 能把 else 和前面if看在一起,有的不能。。。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
永福名
2008-05-20 · TA获得超过206个赞
知道答主
回答量:92
采纳率:0%
帮助的人:109万
展开全部
if else结构要用{ } 封装,你那样导致只有if被放到for 循环里了。
******以下程序已经编译,正确无误******
输入数字1000以内,空间换时间算法:
#include<stdio.h>
void main()
{
int i,j,a[10],b[1000];
for(i=0;i<10;i++)
scanf("%d",&a[i]);
for(i=0;i<1000;i++)
b[i]=1001;
for(i=0;i<10;i++)
for(j=i+1;j<10;j++)
{
if (a[i]==a[j])
b[a[i]]=a[i];
}
printf("******所有重复数字******\n");
for(i=0;i<1000;i++)
if(b[i]!=1001)
printf("%d\t",b[i]);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式