看不懂代码:用递归法将一个整数n转化成字符串。
#include<stdio.h>
int main()
{
void convert(int n);
int number;
printf("input an integer: ");
scanf("%d",&number);
printf("output: ");
if(number<0)
{
putchar('-');
putchar(' ');
number=-number;
}
convert(number);
printf("\n");
return 0;
}
void convert(int n)
{ //这个递归函数我看不懂,看了教材的讲解还是一头雾水,可否详解
int i;
if((i=n/10)!=0)
convert(i);
putchar(n%10+'0');
putchar(32);
} 展开
#include<stdio.h>
void convert(intn){
int i;
if ((i=n/10)!=0)
convert(i);
putchar(n%10+'0');
}
int main(){
int num;
scanf("%d",&num);
if(num<0){
printf("-");
num=-num;
}
convert(num);
printf("\n");
return0;
}
扩展资料:
main()应用:
C++中的main函数
C++继承了C语言的大部分特性,因此保留了“程序总是从main函数开始执行,且总是默认从main函数的return语句或结尾处结束运行”这一传统,
但是要注意,C++中的main函数要想作为程序执行的出入口,必须写在全局(Global)范围,不能写成某个结构体或某个类的成员。
虽然main函数可以作为结构体或者类的成员函数,但相应地会失去作为程序出入口的功能。
C++中全局main函数的书写格式与C语言完全相同,功能也完全相同,且同一C++程序同样只能有一个全局main函数。
Java中的main函数
Java同样是以main函数作为程序执行出入口的,但Java作为“更纯洁”的面向对象语言,它的main函数与C/C++有很大的不同。
首先,返回值的概念淡化,在Java Application中main不允许返回值,因此int main是被禁止的,必须使用void main,int main仅限在JavaBean中使用。
其次,Java中所有的函数必须属于类,没有什么全局函数一说,因此main函数不能是全局成员,必须是某个类的成员。
第三,由于main函数变成了类的成员函数,因此要想直接被系统调用,还必须使用public static使其成为静态函数并具有公开权限。
第四,main函数的参数被简化,只需要提供字符串数组即可,不需要提供参数个数(这是由于Java的数组具有下标检查功能的原因)
Java Application中的main函数一般格式如下(类名可以自定义,但保存为Java源码时,主文件名必须与类名相同,否则可能无法运行)
public class MainDemo{
public static void main(String[]args){
//TODO:在此处写入主函数的内容
}
}
Java Applet的运行机制与Java Application完全不同,因此不需要main函数
C#中的main函数
C#中的main函数与Java大同小异,同样必须是类成员,同样使用字符串数组作唯一参数,同样是静态函数,同样的void main,
与之不同的是:main的首字母变成了大写,即"Main函数“,且是否限定为public级别已经无所谓了(默认没有public,但某些场合可能还是需要public)
另外,需要注意的是,C#中不再有”类名必须与主文件名同名“的限制,即使类名不和主文件名相同,程序照样可以运行。
C#应用程序中的main函数默认是这样的(注意main的首字母已是大写)
C#和C/C++、java不同的是C#不在拘泥于必须从main()函数开始执行,C#是属于事件触发。
class Program{
static void Main(string[]args){
//TODO:在此处写入主函数的内容
}
}
一个整数 3456 要变成 '3456'
只要反复除以10, 商 345, 余数就是 6
那 345 可以再次调用自已进行处理,6就可以+'0' 输出了,
{
商 i= n /10
如果 i 不等于 0
再转换(商i); // 这就是递归了
输出余数的字符
}
void convert(int n)
{
int i;
if((i=n/10)!=0) //n/10就是n去除最后一位数字,如果条件成立,说明n没到最高位,否则,n<10(只有一位数码了),就是最高位。
convert(i);//去除最后一位数后重新验证。
putchar(n%10+'0');//输出当前数的最后一位,递归的效果是从右向左,逐位输出。
putchar(32);//输出空格
}