C语言从1打印到100再打印到1该如何编写?我只服最后一种写法!
我觉得这是一个送分题,奈何人才太多了,给出了各种古怪的写法,如果是做项目的话,我比骄建议一些正常的写法,就是大家都能看得懂的,不要搞什么花里胡哨,不过你要是交流的话,既然是交流,我不觉得要多正规,即使你的观点有问题,我觉得也可以拿出来说说,毕竟是交流,各抒己见,发表自己的观点是最重要的。
—— 为什么不建议大家花里胡哨
我觉得花里胡哨之前首先是你基础非常好了再去花里胡哨,不要自己很多基础的东西还搞不清楚就去花里胡哨。
—— 看这个代码,题外话
看看基础搞不明白的杀伤有多大。
——————————
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该如何编写?我只服最后一种写法!的更多相关文章
- 有三个线程,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; /** * 测试三个线程协 ...
- 多线程下,两个线程交替打印0 -100,使用wait()和notify()
多线程下,两个线程交替打印0 -100,使用wait()和notify() public class ThreadTest{ private static final Object lock = ne ...
- C#实现无物理边距真正可打印区域的绘图\打印程序开发
经常在开发实际的应用程序中,需要用到图形绘制和打印程序.如何实现完整的精确打印和绘图是需要注意许多细节地方的.最近在遇到打印问题的时候,仔细研究一阵,总结这篇博文,写得有点杂乱,看文要还请费点神. 基 ...
- C#实现无物理边距 可打印区域的绘图\打印 z
经常在开发实际的应用程序中,需要用到图形绘制和打印程序.如何实现完整的精确打印和绘图是需要注意许多细节地方的.最近在遇到打印问题的时候,仔细研究一阵,总结这篇博文,写得有点杂乱,看文要还请费点神. 基 ...
- WPF打印原理,自定义打印
一.基础知识 1.System.Printing命名空间 我们可以先看一下System.Printing命名空间,东西其实很多,功能也非常强大,可以说能够控制打印的每一个细节,曾经对PrintDial ...
- 求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) 分析:这题本来很 ...
- C#通过调用WinApi打印PDF文档类,服务器PDF打印、IIS PDF打印
其他网站下载来的类,可以用于Winform.Asp.Net,用于服务器端PDF或其他文件打印. 直接上代码: using System; using System.Collections.Generi ...
- Lodop打印控件指定打印任务某几页
使用Lodop打印控件进行打印开发,有时候一个任务里有多页,例如各种合同之类的,客户端用户在使用过程中,可能有某一页打印后发现需要修改,这时候不必再把整个任务重新打印一遍,只需要打印需要修改的那页重新 ...
- lua 写逻辑打印log时,打印到一半后停止不再打印,程序停止
问题描述:ubuntu下用lua开发游戏电子邮件模块,自己测试时向用户推送100封,而用户最多只能有50封.这是调用sysdelete删除一些邮件.当打印log时,打印到一半后程序中途停止.将打印lo ...
随机推荐
- leetcode刷题-78子集
题目 给定一组不含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集). 说明:解集不能包含重复的子集. 示例: 输入: nums = [1,2,3]输出:[ [3], [1], [2] ...
- 4.FFMPEG-AVFrame
在ffmpeg中,解码前的数据结构体为AVPacket(参考:3.AVPacket使用),而解码后的数据为AVFrame(视频的YUV, RGB, 音频的PCM,数据量更大) 1.AVFrame介绍 ...
- 双向绑定数据的实现(new Proxy 版本)
调用 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8& ...
- 搭建MQTT学习平台
关于MQTT协议的介绍就不赘述了,网上资料非常多,直接入正题. MQTT协议的实现非常多,我选择了一个非常轻量级的开源项目来学习MQTT协议——mosquitto,官网:www.mosquitto.o ...
- python中的算数运算符+、-、*、/、//、%、**
例如a=5,b=2 + 两个对象相加 a+b=7 - 两个对象相减 a- ...
- k8s集群监控(十一)
Weave Scope 在我之前的docker监控中<Docker容器监控(十)–技术流ken>就已经提到了weave scope. Weave Scope 是 Docker 和 Ku ...
- pytest封神之路第三步 精通fixture
首先放一句"狠话". 如果你不会fixture,那么你最好别说自己会pytest. (只是为了烘托主题哈,手上的砖头可以放下了,手动滑稽) fixture是什么 看看源码 def ...
- python中的方向控制函数
方向控制函数:控制海龟方向,包含绝对角度&海龟角度 改变海龟运行方向,让海龟转向 angle :改变行进方向,将海归运行方向改变为某一个绝对的角度 例如 将坐标系中的海龟方向改变为绝对系中的4 ...
- CAS导致的ABA问题以及解决方案
CAS算法实现一个重要前提需要取出内存中某时刻的数据,而在下时刻比较并替换,那么在这个时间差类会导致数据的变化. 上篇文章讲到CAS会出现一个ABA问题.那什么是ABA问题呢? 官方一点的解释就是:当 ...
- 第一篇 Hell wcf
老老实实学WCF 第一篇 Hello WCF WCF(Windows Communication Foundation)是微软公司推出的面向服务技术的集大成者,涵盖继承了其之前发布的所有的分布式应用 ...