唐僧爱吃唐僧肉 2017-04-28 12:35 采纳率: 16.7%
浏览 1673
已采纳

妹子不知道程序错在哪里了,求大神帮帮忙啊

题目:
题目内容:
从键盘输入一个数,检查这个数中是否有重复出现的数字。如果这个数中有重复出现的数字,则显示“Repeated digit!”;否则显示“No repeated digit!”。
已知函数原型:

int CountRepeatNum(int count[], int n);
若有重复数字,则该函数返回重复出现的数字;否则返回-1.
我的程序:
#include
#include
#define N 100
int CountRepeatNum(int count[], int n);
int main()
{
int x,count[N],k=1,m;
long int n,j,u,l;
printf("Input n:\n");
scanf("%ld",&n);
j=n;
l=n;
while(j>=10)
{
j=j/10;
k++;
}//记录数字数位,便于后面分离数字;
j=1;
for(m=1;m {
j=j*10;
}
count[0]=n%10;
//使j是n的数位相同的1打头其余都为零的数,便于后面分离数字;
for(m=1;m {
u=n/j;
count[m-1]=u;
n=n-u*j;
j=j/10;
}//分离每个数位的数字,并将其放置到数组当中;
n=l;//把n返回输入的值;
x=CountRepeatNum(count,n);
if(x==-1)
printf("No repeated digit!\n");
else
printf("Repeated digit!\n");
return 0;
}
int CountRepeatNum(int count[], int n)
{
int k=1,j,u,o=-1;
while(n>=10)
{
n=n/10;
k++;
}//判断接收数的数位(与主函数中一样);
for(j=0;j<k;j++)
{
for(u=0;u<k;u++)
{
if(u!=k&&count[u]==count[k])
o=count[u];
}//判断有无相同的数,如果有返回那个数
}
return o;
}
求大神指点,好像不管有没有重复的数都返回-1;
还有为什么我用codeblocks调试的时候为什么监视不能显示数组的值,只能显示数组的地址,我想看数组的值啊!

  • 写回答

3条回答 默认 最新

  • YXTS122 2017-04-28 13:14
    关注

    if (u!=k&&count[u]==count[k])这个写错了吧,应该是if (u!=j&&count[u]==count[j])

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 MATLAB和mosek的求解问题
  • ¥20 修改中兴光猫sn的时候提示失败
  • ¥15 java大作业爬取网页
  • ¥15 怎么获取欧易的btc永续合约和交割合约的5m级的历史数据用来回测套利策略?
  • ¥15 有没有办法利用libusb读取usb设备数据
  • ¥15 为什么openeluer里面按不了python3呢?
  • ¥15 关于#matlab#的问题:训练序列与输入层维度不一样
  • ¥15 关于Ubuntu20.04.3LTS遇到的问题:在安装完CUDA驱动后,电脑会进入卡死的情况,但可以通过键盘按键进入安全重启,但重启完又会进入该情况!
  • ¥15 关于#嵌入式硬件#的问题:树莓派第一天重装配置python和opencv后第二天打开就成这样,瞎捣鼓搞出来文件夹还是没把原来的界面调回来
  • ¥20 Arduino 循迹小车程序电路出错故障求解