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 ...
随机推荐
- 电子邮箱有哪些隐藏技能,读懂了效率提升N倍!
很多人将邮箱作为常见的通讯工具,然而,大部分职场人只了解其五分之一的功能.电子邮箱还有很多隐藏技能,身为商务精英的你,必须往下看看哦!今天跟随TOM邮箱小编导,来挖掘下邮箱的潜藏技能吧~ 作为经常外出 ...
- 漏洞扫描工具acunetix12会遇到的问题
1.如果安装好之后,打开工具时显示无法访问,首先去看任务管理器当中,acunetix的服务是否启动了 2.如果忘记了账号密码,可以在安装目录下,双击ChangePassword.exe进行重置密码
- oracle之SQL的数据类型
SQL的数据类型 3.1 四种基本的常用数据类型(表的字段类型) 1.字符型, 2.数值型,3.日期型,4.大对象型 3.1.1 字符型: char 固定字符,最长2000个 ...
- BFC与HasLayout的理解
1.(Block Formatting Contexts)BFC 定义 BFC(Block formatting context)直译为"块级格式化上下文".它是一个独立的渲染区域 ...
- Istio中的流量配置
Istio中的流量配置 目录 Istio中的流量配置 Istio注入的容器 Istio-init istio-proxy Envoy架构 Pilot-agent生成的初始配置文件 Envoy管理接口获 ...
- openstack核心组件——cinder存储服务(11)
一.cinder 介绍: 理解 Block Storage 操作系统获得存储空间的方式一般有两种: 通过某种协议(SAS,SCSI,SAN,iSCSI 等)挂接裸硬盘,然后分区.格式化.创建文件系 ...
- 熬夜23天吃透,九大核心专题,成功收割了阿里、百度、美团3家offer
前言 今年受疫情影响非常大,春招和金三银四都要比往年来得更迟一些.春招结束之后,我特意把自己的面试经历顺了顺,总结出了不少的经验.对了,这次一共收割了3个大厂offer,分别是蚂蚁金服.美团和网易,特 ...
- vue中父子组件传值问题 通过props 和 $emit()方法
(代码在最后) 1.父组件给子组件传值直接通过props,听着很简单,但是对于初学者来说还是比较难以理解的,今天小白通过自己的实践操作结合代码分析一下 案例 把模态框单独的抽离出来,当作一个组件 第 ...
- FTP服务端 FTP服务端搭建教程
FTP服务端搭建教程如下:一.需要准备以下工具:1.微型FTP服务端.2.服务器管理工具二.操作步骤:1.下载微型FTP服务端.(站长工具包可下载:http://zzgjb.iis7.com/ )2. ...
- Python-信号量和线程池-semaphore ThreadPollExector
信号量 其实本质上是锁,Lock是单锁,信号量是指定多把锁,也就是说通过信号量指定多个数线程可以访问相同资源,一般情况下读操作可以有多个,但写操作同时只有一个 信号量模块 semaphore # 使用 ...