我觉得这是一个送分题,奈何人才太多了,给出了各种古怪的写法,如果是做项目的话,我比骄建议一些正常的写法,就是大家都能看得懂的,不要搞什么花里胡哨,不过你要是交流的话,既然是交流,我不觉得要多正规,即使你的观点有问题,我觉得也可以拿出来说说,毕竟是交流,各抒己见,发表自己的观点是最重要的。

—— 为什么不建议大家花里胡哨

我觉得花里胡哨之前首先是你基础非常好了再去花里胡哨,不要自己很多基础的东西还搞不清楚就去花里胡哨。

—— 看这个代码,题外话

看看基础搞不明白的杀伤有多大。

——————————

void start_f(int first_start)

{

 char time_buf[512];

 char buf[512];

 if(!first_start)

 {

  sprintf(time_buf,"%s",get_time());

  int len = strlen(time_buf);

  time_buf[len -1 ] = 0;

  printf("time_buf:%s\n",time_buf);

 }

}

——————————

这个是在网上看到的一个代码,比较典型的基础不牢靠,对strlen 理解不够。

常规解题代码

我觉得对于这个题目,使用for是非常常规的思考方式,所以我看了所有的回答之后,写了一个常规的代码。

—— 代码如下:

——————————

#include "stdio.h"

void main(void)

{

 int i=0;

 for(i=1;i<=100;i++)

 {

  printf("%d ",i);

 }

 for(i=99;i>=1;i--)

 {

  printf("%d ",i);

 }

} 

——————————

代码输出:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 99 98 97 96 95 94 93 92 91 90 89 88 87 86 85 84 83 82 81 80 79 78 77 76 75 74 73 72 71 70 69 68 67 66 65 64 63 62 61 60 59 58 57 56 55 54 53 52 51 50 49 48 47 46 45 44 43 42 41 40 39 38 37 36 35 34 33 32 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1

————————

Process exited after 0.04664 seconds withreturnvalue 2

请按任意键继续. . .

—— 为什么是 void main ,而不是Int main ,题外话

这个是一个留言提到的,很多人也对这个有疑惑,main 的写法有几种,有的被认为是正规的,有的被认为是不正规的。

main是一个函数,既然是一个函数,就遵从函数的规则就好。

所以,这样写输出并没有什么问题

——————————

#include <stdio.h>

char * main()

{

printf("hhh\n");

    return (char * )NULL;

}

——————————

我们还要知道比较常见的几种

——————————

int main(int argc,char **argv){}

int main(int argc,char *argv[]){}

int main(void){}

——————————

—— 对于返回值的认知

main 函数是被操作系统调用的,既然是被操作系统调用的,操作系统会判断函数的返回值,通过返回值来判断程序是否正确运行,所以main函数的返回值是有意义的,我示例中的写法并不规范。

对main的解读

 

比较玄乎的写法:

——————————

#include "stdio.h"

void fun(int n)

{

 if(n<100)

 {

  printf("%d ",n); 

  fun(n+1);

 } 

 printf("%d ",n);

}

int main(void)

{

 fun(1);

 return 0;

}

——————————

程序输出:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 99 98 97 96 95 94 93 92 91 90 89 88 87 86 85 84 83 82 81 80 79 78 77 76 75 74 73 72 71 70 69 68 67 66 65 64 63 62 61 60 59 58 57 56 55 54 53 52 51 50 49 48 47 46 45 44 43 42 41 40 39 38 37 36 35 34 33 32 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1

--------------------------------

Process exited after 0.05336 seconds with return value 0

请按任意键继续. . .

这里涉及到递归,如果没有这个概念的人,脑子可能弯不过来

大概是这样执行顺序的:

——————————

fun(1)

->fun(2)

--->fun(3)

........

---->fun(99)

把上面的代码修改下:

#include "stdio.h"

void fun(int n)

{

 if(n<100)

 {

  printf("fun(%d) ",n); 

  fun(n+1);

 } 

 printf("fun(%d) ",n);

}

int main(void)

{

 fun(1);

 return 0;

}
——————————

        代码输出

fun(1) fun(2) fun(3) fun(4) fun(5) fun(6) fun(7) fun(8) fun(9) fun(10) fun(11) fun(12) fun(13) fun(14) fun(15) fun(16) fun(17) fun(18) fun(19) fun(20) fun(21) fun(22) fun(23) fun(24) fun(25) fun(26) fun(27) fun(28) fun(29) fun(30) fun(31) fun(32) fun(33) fun(34) fun(35) fun(36) fun(37) fun(38) fun(39) fun(40) fun(41) fun(42) fun(43) fun(44) fun(45) fun(46) fun(47) fun(48) fun(49) fun(50) fun(51) fun(52) fun(53) fun(54) fun(55) fun(56) fun(57) fun(58) fun(59) fun(60) fun(61) fun(62) fun(63) fun(64) fun(65) fun(66) fun(67) fun(68) fun(69) fun(70) fun(71) fun(72) fun(73) fun(74) fun(75) fun(76) fun(77) fun(78) fun(79) fun(80) fun(81) fun(82) fun(83) fun(84) fun(85) fun(86) fun(87) fun(88) fun(89) fun(90) fun(91) fun(92) fun(93) fun(94) fun(95) fun(96) fun(97) fun(98) fun(99) fun(100) fun(99) fun(98) fun(97) fun(96) fun(95) fun(94) fun(93) fun(92) fun(91) fun(90) fun(89) fun(88) fun(87) fun(86) fun(85) fun(84) fun(83) fun(82) fun(81) fun(80) fun(79) fun(78) fun(77) fun(76) fun(75) fun(74) fun(73) fun(72) fun(71) fun(70) fun(69) fun(68) fun(67) fun(66) fun(65) fun(64) fun(63) fun(62) fun(61) fun(60) fun(59) fun(58) fun(57) fun(56) fun(55) fun(54) fun(53) fun(52) fun(51) fun(50) fun(49) fun(48) fun(47) fun(46) fun(45) fun(44) fun(43) fun(42) fun(41) fun(40) fun(39) fun(38) fun(37) fun(36) fun(35) fun(34) fun(33) fun(32) fun(31) fun(30) fun(29) fun(28) fun(27) fun(26) fun(25) fun(24) fun(23) fun(22) fun(21) fun(20) fun(19) fun(18) fun(17) fun(16) fun(15) fun(14) fun(13) fun(12) fun(11) fun(10) fun(9) fun(8) fun(7) fun(6) fun(5) fun(4) fun(3) fun(2) fun(1)

        重点在于只有if 判断为假后,才结束递归,但是递归不能无限大,太大了会撑爆栈空间的
再看看下面这个高赞的奇葩写法:
#include <stdio.h>

int main() {

printf("1");

printf(" ");

printf("2");

printf(" ");

printf("3");

printf(" ");

printf("4");

printf(" ");

printf("5");

printf(" ");

printf("6");

printf(" ");

printf("7");

printf(" ");

printf("8");

printf(" ");

printf("9");

printf(" ");

printf("10");

printf(" ");

printf("11");

printf(" ");

printf("12");

printf(" ");

printf("13");

printf(" ");

printf("14");

printf(" ");

printf("15");

printf(" ");

printf("16");

printf(" ");

printf("17");

printf(" ");

printf("18");

printf(" ");

printf("19");

printf(" ");

printf("20");

printf(" ");

printf("21");

printf(" ");

printf("22");

printf(" ");

printf("23");

printf(" ");

printf("24");

printf(" ");

printf("25");

printf(" ");

printf("26");

printf(" ");

printf("27");

printf(" ");

printf("28");

printf(" ");

printf("29");

printf(" ");

printf("30");

printf(" ");

printf("31");

printf(" ");

printf("32");

printf(" ");

printf("33");

printf(" ");

printf("34");

printf(" ");

printf("35");

printf(" ");

printf("36");

printf(" ");

printf("37");

printf(" ");

printf("38");

printf(" ");

printf("39");

printf(" ");

printf("40");

printf(" ");

printf("41");

printf(" ");

printf("42");

printf(" ");

printf("43");

printf(" ");

printf("44");

printf(" ");

printf("45");

printf(" ");

printf("46");

printf(" ");

printf("47");

printf(" ");

printf("48");

printf(" ");

printf("49");

printf(" ");

printf("50");

printf(" ");

printf("51");

printf(" ");

printf("52");

printf(" ");

printf("53");

printf(" ");

printf("54");

printf(" ");

printf("55");

printf(" ");

printf("56");

printf(" ");

printf("57");

printf(" ");

printf("58");

printf(" ");

printf("59");

printf(" ");

printf("60");

printf(" ");

printf("61");

printf(" ");

printf("62");

printf(" ");

printf("63");

printf(" ");

printf("64");

printf(" ");

printf("65");

printf(" ");

printf("66");

printf(" ");

printf("67");

printf(" ");

printf("68");

printf(" ");

printf("69");

printf(" ");

printf("70");

printf(" ");

printf("71");

printf(" ");

printf("72");

printf(" ");

printf("73");

printf(" ");

printf("74");

printf(" ");

printf("75");

printf(" ");

printf("76");

printf(" ");

printf("77");

printf(" ");

printf("78");

printf(" ");

printf("79");

printf(" ");

printf("80");

printf(" ");

printf("81");

printf(" ");

printf("82");

printf(" ");

printf("83");

printf(" ");

printf("84");

printf(" ");

printf("85");

printf(" ");

printf("86");

printf(" ");

printf("87");

printf(" ");

printf("88");

printf(" ");

printf("89");

printf(" ");

printf("90");

printf(" ");

printf("91");

printf(" ");

printf("92");

printf(" ");

printf("93");

printf(" ");

printf("94");

printf(" ");

printf("95");

printf(" ");

printf("96");

printf(" ");

printf("97");

printf(" ");

printf("98");

printf(" ");

printf("99");

printf(" ");

printf("100");

printf(" ");

printf("99");

printf(" ");

printf("98");

printf(" ");

printf("97");

printf(" ");

printf("96");

printf(" ");

printf("95");

printf(" ");

printf("94");

printf(" ");

printf("93");

printf(" ");

printf("92");

printf(" ");

printf("91");

printf(" ");

printf("90");

printf(" ");

printf("89");

printf(" ");

printf("88");

printf(" ");

printf("87");

printf(" ");

printf("86");

printf(" ");

printf("85");

printf(" ");

printf("84");

printf(" ");

printf("83");

printf(" ");

printf("82");

printf(" ");

printf("81");

printf(" ");

printf("80");

printf(" ");

printf("79");

printf(" ");

printf("78");

printf(" ");

printf("77");

printf(" ");

printf("76");

printf(" ");

printf("75");

printf(" ");

printf("74");

printf(" ");

printf("73");

printf(" ");

printf("72");

printf(" ");

printf("71");

printf(" ");

printf("70");

printf(" ");

printf("69");

printf(" ");

printf("68");

printf(" ");

printf("67");

printf(" ");

printf("66");

printf(" ");

printf("65");

printf(" ");

printf("64");

printf(" ");

printf("63");

printf(" ");

printf("62");

printf(" ");

printf("61");

printf(" ");

printf("60");

printf(" ");

printf("59");

printf(" ");

printf("58");

printf(" ");

printf("57");

printf(" ");

printf("56");

printf(" ");

printf("55");

printf(" ");

printf("54");

printf(" ");

printf("53");

printf(" ");

printf("52");

printf(" ");

printf("51");

printf(" ");

printf("50");

printf(" ");

printf("49");

printf(" ");

printf("48");

printf(" ");

printf("47");

printf(" ");

printf("46");

printf(" ");

printf("45");

printf(" ");

printf("44");

printf(" ");

printf("43");

printf(" ");

printf("42");

printf(" ");

printf("41");

printf(" ");

printf("40");

printf(" ");

printf("39");

printf(" ");

printf("38");

printf(" ");

printf("37");

printf(" ");

printf("36");

printf(" ");

printf("35");

printf(" ");

printf("34");

printf(" ");

printf("33");

printf(" ");

printf("32");

printf(" ");

printf("31");

printf(" ");

printf("30");

printf(" ");

printf("29");

printf(" ");

printf("28");

printf(" ");

printf("27");

printf(" ");

printf("26");

printf(" ");

printf("25");

printf(" ");

printf("24");

printf(" ");

printf("23");

printf(" ");

printf("22");

printf(" ");

printf("21");

printf(" ");

printf("20");

printf(" ");

printf("19");

printf(" ");

printf("18");

printf(" ");

printf("17");

printf(" ");

printf("16");

printf(" ");

printf("15");

printf(" ");

printf("14");

printf(" ");

printf("13");

printf(" ");

printf("12");

printf(" ");

printf("11");

printf(" ");

printf("10");

printf(" ");

printf("9");

printf(" ");

printf("8");

printf(" ");

printf("7");

printf(" ");

printf("6");

printf(" ");

printf("5");

printf(" ");

printf("4");

printf(" ");

printf("3");

printf(" ");

printf("2");

printf(" ");

printf("1");

printf(" ");

return 0;

}
#include "stdio.h"

void fun(int n)

{

 if(n<100)

 {

  printf("fun(%d) ",n); 

  fun(n+1);

 } 

 printf("fun(%d) ",n);

}

int main(void)

{

 fun(1);

 return 0;

}

——————————

        代码输出

fun(1) fun(2) fun(3) fun(4) fun(5) fun(6) fun(7) fun(8) fun(9) fun(10) fun(11) fun(12) fun(13) fun(14) fun(15) fun(16) fun(17) fun(18) fun(19) fun(20) fun(21) fun(22) fun(23) fun(24) fun(25) fun(26) fun(27) fun(28) fun(29) fun(30) fun(31) fun(32) fun(33) fun(34) fun(35) fun(36) fun(37) fun(38) fun(39) fun(40) fun(41) fun(42) fun(43) fun(44) fun(45) fun(46) fun(47) fun(48) fun(49) fun(50) fun(51) fun(52) fun(53) fun(54) fun(55) fun(56) fun(57) fun(58) fun(59) fun(60) fun(61) fun(62) fun(63) fun(64) fun(65) fun(66) fun(67) fun(68) fun(69) fun(70) fun(71) fun(72) fun(73) fun(74) fun(75) fun(76) fun(77) fun(78) fun(79) fun(80) fun(81) fun(82) fun(83) fun(84) fun(85) fun(86) fun(87) fun(88) fun(89) fun(90) fun(91) fun(92) fun(93) fun(94) fun(95) fun(96) fun(97) fun(98) fun(99) fun(100) fun(99) fun(98) fun(97) fun(96) fun(95) fun(94) fun(93) fun(92) fun(91) fun(90) fun(89) fun(88) fun(87) fun(86) fun(85) fun(84) fun(83) fun(82) fun(81) fun(80) fun(79) fun(78) fun(77) fun(76) fun(75) fun(74) fun(73) fun(72) fun(71) fun(70) fun(69) fun(68) fun(67) fun(66) fun(65) fun(64) fun(63) fun(62) fun(61) fun(60) fun(59) fun(58) fun(57) fun(56) fun(55) fun(54) fun(53) fun(52) fun(51) fun(50) fun(49) fun(48) fun(47) fun(46) fun(45) fun(44) fun(43) fun(42) fun(41) fun(40) fun(39) fun(38) fun(37) fun(36) fun(35) fun(34) fun(33) fun(32) fun(31) fun(30) fun(29) fun(28) fun(27) fun(26) fun(25) fun(24) fun(23) fun(22) fun(21) fun(20) fun(19) fun(18) fun(17) fun(16) fun(15) fun(14) fun(13) fun(12) fun(11) fun(10) fun(9) fun(8) fun(7) fun(6) fun(5) fun(4) fun(3) fun(2) fun(1)

        重点在于只有if 判断为假后,才结束递归,但是递归不能无限大,太大了会撑爆栈空间的哦

递归的文章

C 语言,你真的懂递归了吗?

比如这样:

C语言从1打印到100再打印到1该如何编写?我只服最后一种写法!的更多相关文章

  1. 有三个线程,a、b、c,a打印“T1”,b打印“T2”,c打印“T3”,a执行完后,b执行;b执行完后,c执行。如此循环100遍

    有三个线程,a.b.c,a打印“T1”,b打印“T2”,c打印“T3”,a执行完后,b执行:b执行完后,c执行.如此循环100遍. package com.company; /** * 测试三个线程协 ...

  2. 多线程下,两个线程交替打印0 -100,使用wait()和notify()

    多线程下,两个线程交替打印0 -100,使用wait()和notify() public class ThreadTest{ private static final Object lock = ne ...

  3. C#实现无物理边距真正可打印区域的绘图\打印程序开发

    经常在开发实际的应用程序中,需要用到图形绘制和打印程序.如何实现完整的精确打印和绘图是需要注意许多细节地方的.最近在遇到打印问题的时候,仔细研究一阵,总结这篇博文,写得有点杂乱,看文要还请费点神. 基 ...

  4. C#实现无物理边距 可打印区域的绘图\打印 z

    经常在开发实际的应用程序中,需要用到图形绘制和打印程序.如何实现完整的精确打印和绘图是需要注意许多细节地方的.最近在遇到打印问题的时候,仔细研究一阵,总结这篇博文,写得有点杂乱,看文要还请费点神. 基 ...

  5. WPF打印原理,自定义打印

    一.基础知识 1.System.Printing命名空间 我们可以先看一下System.Printing命名空间,东西其实很多,功能也非常强大,可以说能够控制打印的每一个细节,曾经对PrintDial ...

  6. 求1+2+…+n,要求不能使用乘除法、for、while、if、else、s witch、case 等关键字以及条件判断语句(A?B:C)和不用循环/goto/递归输出1~100的10种写法

    来源:据说是某一年某个公司的面试题 题目:求1+2+…+n, 要求不能使用乘除法.for.while.if.else.s witch.case 等关键字以及条件判断语句(A?B:C) 分析:这题本来很 ...

  7. C#通过调用WinApi打印PDF文档类,服务器PDF打印、IIS PDF打印

    其他网站下载来的类,可以用于Winform.Asp.Net,用于服务器端PDF或其他文件打印. 直接上代码: using System; using System.Collections.Generi ...

  8. Lodop打印控件指定打印任务某几页

    使用Lodop打印控件进行打印开发,有时候一个任务里有多页,例如各种合同之类的,客户端用户在使用过程中,可能有某一页打印后发现需要修改,这时候不必再把整个任务重新打印一遍,只需要打印需要修改的那页重新 ...

  9. lua 写逻辑打印log时,打印到一半后停止不再打印,程序停止

    问题描述:ubuntu下用lua开发游戏电子邮件模块,自己测试时向用户推送100封,而用户最多只能有50封.这是调用sysdelete删除一些邮件.当打印log时,打印到一半后程序中途停止.将打印lo ...

随机推荐

  1. 【极致丝滑】彻底摆脱编辑器插件,利用postcss灵活可控地转换px至vw

    背景 旧的rem适配方案(无论是直接使用rem,还是配合flexiblejs等lib库进行视口缩放)已经疲态尽显,且随着安卓高清屏的不断出现,同时data-dpr仍有进一步增加的可能性,rem显得并不 ...

  2. oracle之二检查点

    检查点(checkpoint) 8.1 什么是checkpointcheckpoint是数据库的一个内部事件,检查点激活时会触发数据库写进程(DBWR),将数据缓冲区里的脏数据块写到数据文件中. 8. ...

  3. 老男孩教育python全栈第22期Day15笔记

    day15 今日内容大纲 昨日内容回顾作业讲解 装饰器:完美的呈现了开放封闭原则.装饰器的本质:闭包. def wraper(f): def inner(*args, **kwargs): " ...

  4. Spring源码解析 | 第二篇:Spring IOC容器之XmlBeanFactory启动流程分析和源码解析

    一. 前言 Spring容器主要分为两类BeanFactory和ApplicationContext,后者是基于前者的功能扩展,也就是一个基础容器和一个高级容器的区别.本篇就以BeanFactory基 ...

  5. JavaGuide易错点总结

    基础知识易错点 1. object.equals("str") 容易报空指针异常,应使用"str".equals(object); 还可以使用JDK7引入的工具 ...

  6. Linux中逻辑卷(LV)的创建、增大和减小

    首先说一下在缩小逻辑卷的时候要注意的问题:第一步使用resize2fs命令更改文件系统的容量:第二步使用lvreduce命令减小逻辑卷的容量.这两个顺序千万不要搞反了,而且要保证缩减后的逻辑卷容量大于 ...

  7. k8s控制器资源

    k8s控制器资源   Pod pod在之前说过,pod是kubernetes集群中是最小的调度单元,pod中可以运行多个容器,而node又可以包含多个pod,关系如下图: 在对pod的用法进行说明之前 ...

  8. svg的学习

    svg的学习 1,初步了解 1,大致看了一下svg的简介,在图形的操作和展示上有很大的优势,例如不会失精:灵活的dom操作:很好的兼容性(IE需要下载插件).so,是一门值得深究的前端课程: 2,看了 ...

  9. vulnhub靶机Os-hackNos-1

    vulnhub靶机Os-hackNos-1 信息搜集 nmap -sP 192.168.114.0/24 找到开放机器192.168.114.140这台机器,再对这台靶机进行端口扫描. 这里对他的端口 ...

  10. 转载:关于Python3中venv虚拟环境

    https://www.cnblogs.com/zhaof/p/7299025.html