我也说不清是哪的问题,输入的次数少于6就没毛病,已超过就完蛋了
#include<stdio.h>/* 输入一组数据 放到数组中然后将重复的数其中一个变成0
我这个出了问题了,不知道为什么 只要输入的数超过6个 就
无法在输入了,大家帮忙看下怎么回事呢 */
int main()
{
int i=0,j,temp,m;
int a;
printf("请输入\n");
do{
scanf("%d",&a);
//a=getchar();
//int(a);
i=i+1;
}
while(a!=0);
m=i-1;
for(j=0;j<m-1;j++)
for(i=j+1;i<m;i++)
{
if(a==a)
char(a='\t');
}
for(i=0;i<m;i++)
printf("%d\t",a);
return 0;
} 本帖最后由 Croper 于 2019-3-26 21:51 编辑
话说你这很多写法都有问题啊
#include<stdio.h>
int main()
{
int i=0,j,temp,m;
int a; //这是什么写法,先不说常量表达式的问题,你这声明了一个零长度的数组是要搞哪样
printf("请输入\n");
do{
scanf("%d",&a);
i=i+1;
}while(a!=0);
m=i-1;
for(j=0;j<m-1;j++)
for(i=j+1;i<m;i++)
{
if(a==a)
char(a='t');//这又是什么新写法,强制类型转换也不是这样写啊,然后你把一个整数赋值成⑨是要干什么
}
for(i=0;i<m;i++)
printf("%d\t",a);
return 0;
}
不过还好,思路没问题,把这两个地方改了就行#include<stdio.h>
int main()
{
int i = 0, j, temp, m;
int a;
printf("请输入n\n");
do {
scanf("%d", &a);
i = i + 1;
} while (a != 0);
m = i - 1;
for (j = 0; j < m - 1; j++) {
for (i = j + 1; i < m; i++)
{
if (a == a) {
a = 0;
break; //这里可以加个break,避免重复运算
}
}
}
for (i = 0; i < m; i++) printf("%d\t", a);
return 0;
}
Croper 发表于 2019-3-26 21:42
话说你这很多写法都有问题啊
不过还好,思路没问题,把这两个地方改了就行
大佬 我在问你几个问题
1.啥叫重复运算啊
2.为啥在那加个break
3.可以换个别的什么东西表示结束吗 就是把我那个0给换成个别的 比如A-Z啥的字符
4.最后怎么把我替换成0,替换成别的东西最好是空白的 如果我的数据里有0就完蛋了
/*******谢谢大佬******/ 蜗牛冲上天 发表于 2019-3-26 22:33
大佬 我在问你几个问题
1.啥叫重复运算啊
2.为啥在那加个break
我定义的那个数组 不是瞎定义的 ,因为不知道 用户会输入多少个数,这样定义不会使数组的内存被浪费,反正C99支持 数组大小可以改变 哈哈不是随便定义的0长度数组奥哈哈 蜗牛冲上天 发表于 2019-3-26 22:33
大佬 我在问你几个问题
1.啥叫重复运算啊
2.为啥在那加个break
1.啥叫重复运算啊
2.为啥在那加个
比如在数据{1,2,3,1,4}中,当j=3是,i=0时,已经有a[ i]==a了,就不需要再继续比a是否等于a,a是否等于a了,直接break掉;
3.可以换个别的什么东西表示结束吗 就是把我那个0给换成个别的 比如A-Z啥的字符
4.最后怎么把我替换成0,替换成别的东西最好是空白的 如果我的数据里有0就完蛋了
你既然已经printf("%d"),那么就是告诉编译器把这段数据当整数来解释,既然解释成整数了,怎么把这个数据显示成空白,
你一定要空白,加个判断,等于0就不显示呗 蜗牛冲上天 发表于 2019-3-26 22:37
我定义的那个数组 不是瞎定义的 ,因为不知道 用户会输入多少个数,这样定义不会使数组的内存被浪费,反 ...
谁告诉你变长数组是这么用的?先去把相关概念搞清楚,
从你问的问题就能看出来,你对内存根本没有概念,先去看看数据在内存里怎么存储,什么是栈,什么是堆,然后再来按自己的想法来写 Croper 发表于 2019-3-26 23:04
谁告诉你变长数组是这么用的?先去把相关概念搞清楚,
从你问的问题就能看出来,你对内存根本没有概念, ...
的确 不太清楚 我们刚开这门课,老师还没讲到 数组跟指针,自己学的 也不扎实, 谢谢大佬,我这样定义数组我也感觉有隐患,但是假如不知道数组长度是多少,该怎样定义个数组才比较好呢 Croper 发表于 2019-3-26 23:01
比如在数据{1,2,3,1,4}中,当j=3是,i=0时,已经有a[ i]==a了,就不需要再继续比a是否等于a ...
大佬,这个重复运算有问题,我这个程序是想把 所有重复的数字只留下一个,你这样做 后边会继续有重复的比如输入 13151
得到的结果是13051 蜗牛冲上天 发表于 2019-3-26 23:14
的确 不太清楚 我们刚开这门课,老师还没讲到 数组跟指针,自己学的 也不扎实, 谢谢大佬,我这样定义数 ...
一般来说,往大的定义就是了,现在的电脑不差那点内存,
要知道,C和C++里,不存在真正的变长数组,如果你一定要实现内存的高效利用的话,一般是考虑动态内存:
int arr_size=5
int* arr= (int*)malloc(sizeof(int)*arr_size)
这样就申请了一个5个整数大小的数组,当5个整数的空间不够用时
arr_size+=5;
arr=(int*)realloc(arr,sizeof(int)*arr_size);
这样就把数组的大小扩展到了10个整数的空间
但是这种扩展其实是把这段内存里的数据拷贝到其他足够大小片段中,然后再将这段内存释放掉,本身这个过程就是极耗时间的。另外,这种动态申请的内存都是保存在堆里的,而直接申明的数组保存在栈里。而堆里的数据访问本身就比栈里要慢。所以在大部分时候,这种做法的效率是比直接定义一个大数组要低的。
如果你了解c++,stl库里的一堆容器仿佛实现了可变长度的数组,但底层仍然是和上面相似的方法,如果你非要一个字节一个字节地扣长度,那最终只能是降低程序的效率
蜗牛冲上天 发表于 2019-3-26 23:36
大佬,这个重复运算有问题,我这个程序是想把 所有重复的数字只留下一个,你这样做 后边会继续有重复的比 ...
好吧,break确实不应该在那儿,
但是改一下遍历顺序就能加入break for (i=1;i<m;++i){
for (j=0;j<i;++j){
if (a==a){
a=0;
break;
}
}
}
页:
[1]