同一个算法写的,为什么C语言和Java的结果不一样啊

ming_311 2012-08-04 04:32:39
public class Test{

public static int sum=0;
public static void main(String[] arg)
{
System.out.print(fun(5));
}
public static int fun(int n) {

if (n == 1)
return 1;
else
sum += fun(n - 1);

return sum;
}

#include<stdio.h>
int sum=0;
int fun(int n) {

if (n == 1)
return 1;
else
sum += fun(n - 1);

return sum;
}

int main()
{
printf("%d",fun(5));

return 0;
}

java程序的结果是1,C程序的结果是8,为什么啊?
我认为结果应该是8,难道Java的写得有问题?
...全文
418 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
ming_311 2012-08-30
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 的回复:]

问题还是出在这个表达式上:sum += fun(n - 1);
后面的fun(n-1)在计算时含有sum,算下来成这样的表达式:
sum=sum+++sum+++sum+++sum++;java编译器有自己的计算顺序,它可以在计算之前把sum装入了寄存器,等fun(n-1)返回把结果一加,再存入sum,那结果就离题太远了;
而C编译器也并无规定变量的计算顺序。
这,就是差别。
答案就是……
[/Quote]
++1
ming_311 2012-08-30
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 的回复:]

问题还是出在这个表达式上:sum += fun(n - 1);
后面的fun(n-1)在计算时含有sum,算下来成这样的表达式:
sum=sum+++sum+++sum+++sum++;java编译器有自己的计算顺序,它可以在计算之前把sum装入了寄存器,等fun(n-1)返回把结果一加,再存入sum,那结果就离题太远了;
而C编译器也并无规定变量的计算顺序。
这,就是差别。
答案就是……
[/Quote]
++1
ljhhh0123 2012-08-06
  • 打赏
  • 举报
回复
全是错误的递归写法!!!
假如楼主实现的是n到1的连加。实现如下:
public class Test{


public static void main(String[] arg)
{

System.out.println(fun(5));
}
public static int fun(int n) {

if (n == 1)
return 1;
else
return n+fun(n - 1);

}
}

#include<stdio.h>
int fun(int n) {

if (n == 1)
return 1;
else
return n+fun(n - 1);
}

int main()
{
printf("%d",fun(5));

return 0;
}
ljhhh0123 2012-08-06
  • 打赏
  • 举报
回复
问题还是出在这个表达式上:sum += fun(n - 1);
后面的fun(n-1)在计算时含有sum,算下来成这样的表达式:
sum=sum+++sum+++sum+++sum++;java编译器有自己的计算顺序,它可以在计算之前把sum装入了寄存器,等fun(n-1)返回把结果一加,再存入sum,那结果就离题太远了;
而C编译器也并无规定变量的计算顺序。
这,就是差别。
答案就是将这个语句拆开。else后的语句分拆成这样:
else{
int i=fun(n-1);
sum +=i;
}

编译结果就一样了。
kingxuke 2012-08-05
  • 打赏
  • 举报
回复
有意思的问题,尝试了好久(周末都没了),没有解决,后来在 stackoverflow 上发了个帖子询问,终于有了答案。

帖子地址:
http://stackoverflow.com/questions/11813692/java-recursion-bug-i-am-going-crazy/11813707#11813707

就不翻译成中文了,楼主自己看吧,希望楼主可以理解,Good Luck!
竞天问 2012-08-04
  • 打赏
  • 举报
回复
这个递归还真是不一般
  • 打赏
  • 举报
回复
sum += fun(n - 1);
你在用递归调用吗?明显不规范啊,我感觉你两个都是错的- -!
sum=5 返回fun(4)然后计算fun(4)=fun(3)
当你计算fun(1)的时候n等于1,于是java就直接返回了1.
不知道你想计算什么,是fun(5)+fun(4)++
还是其他什么?
Yueyugezhu 2012-08-04
  • 打赏
  • 举报
回复

public class Test{

//public static int sum=0;
public static void main(String[] arg)
{
System.out.print(fun(5));
}
public static int fun(int n) {
int sum= n;

if (n == 1)
return 1;
else
sum += fun(n - 1);

return sum;
}



#include<stdio.h>
//int sum=0;
int fun(int n) {
int sum = n;

if (n == 1)
return 1;
else
sum += fun(n - 1);

return sum;
}

int main()
{
printf("%d",fun(5));

system("pause");
return 0;
}
全国计算机等级考试2级C语言题库(电子版) 很多人对学习C语言感到无从下手,经常问我同一个问题:究竟怎样学习C语言?我是一个教师,已经开发了很多年的程序,和很多刚刚起步的人一样,学习的第一个计算机语言就是C语言。经过这些年的开发,我深深的体会到C语言对于一个程序设计人员多么的重要,如果不懂C语言,你想底层程序这几乎听起来很可笑,不懂C语言,你想出优秀高效的程序,这简直就是天方夜谭。为什么C语言如此重要呢? 第一:C语言语法结构很简洁精妙,出的程序也很高效,很便于描述算法,大多数的程序员愿意使用C语言去描述算法本身,所以,如果你想在程序设计方面有所建树,就必须去学它。 第二:C语言能够让你深入系统底层,你知道的操作系统,哪一个不是C语言的?所有的windows,Unix,Linux,Mac,os/2,没有一个里外的,如果你不懂C语言,怎么可能深入到这些操作系统当中去呢?更不要说你去它们的内核程序了。 第三:很多新型的语言都是衍生自C语言,C++,Java,C#,J#,perl...哪个不是呢?掌握了C语言,可以说你就掌握了很多门语言,经过简单的学习,你就可以用这些新型的语言去 开发了,这个再一次验证了C语言是程序设计的重要基础。还有啊,多说一点:即使现在招聘程序员,考试都是考C语言,你想加入it行业,那么就一定要掌握好C语言
很多人对学习C语言感到无从下手,经常问我同一个问题:究竟怎样学习C语言?我是一个教师,已经开发了很多年的程序,和很多刚刚起步的人一样,学习的第一个计算机语言就是C语言。经过这些年的开发,我深深的体会到C语言对于一个程序设计人员多么的重要,如果不懂C语言,你想底层程序这几乎听起来很可笑,不懂C语言,你想出优秀高效的程序,这简直就是天方夜谭。为什么C语言如此重要呢?   第一:C语言语法结构很简洁精妙,出的程序也很高效,很便于描述算法,大多数的程序员愿意使用C语言去描述算法本身,所以,如果你想在程序设计方面有所建树,就必须去学它。   第二:C语言能够让你深入系统底层,你知道的操作系统,哪一个不是C语言的?所有的windows,Unix,Linux,Mac,os/2,没有一个里外的,如果你不懂C语言,怎么可能深入到这些操作系统当中去呢?更不要说你去它们的内核程序了。   第三:很多新型的语言都是衍生自C语言,C++,Java,C#,J#,perl...哪个不是呢?掌握了C语言,可以说你就掌握了很多门语言,经过简单的学习,你就可以用这些新型的语言去开发了,这个再一次验证了C语言是程序设计的重要基础。还有啊,多说一点:即使现在招聘程序员,考试都是考C语言,你想加入it行业,那么就一定要掌握好C语言

64,649

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧