您好,欢迎进入江南娱乐手机客户端 官方网站!

您现在的位置:首页 新闻资讯 >> 新闻头条 >> C语言100个经典的算法之兔子总数计算内含printf的用法
新闻资讯
NEWS INFORMATION

C语言100个经典的算法之兔子总数计算内含printf的用法

关键字:C语言教程 发布时间:2019-05-22

语言的学习基础,100个经典的算法

C语言的学习要从基础开始,这里是100个经典的算法-1C语言的学习要从基础开始,这里是100个经典的算法

题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,

假如兔子都不死,问每个月的兔子总数为多少?

程序分析:兔子的规律为数列1,1,2,3,5,8,13,21....(单位为 对)

main()
{
long f1,f2;
int i;
f1=f2=1;
for(i=1;i<=20;i++)
 { printf("%12ld %12ld",f1,f2);
   if(i%2==0) printf("\n");/*控制输出,每行四个*/
   f1=f1+f2;/*前两个月加起来赋值给第三个月*/
   f2=f1+f2;/*前两个月加起来赋值给第三个月*/
 }
}

我改完之后,出现了点问题,目前还在解决中。

#include<stdio.h>
#include <stdlib.h>

void main()
{
    long int f1,f2,f3;/*f1为前一个月兔子的个数,f2为后一个月兔子的个数,f3为前一个兔子与后一个兔子总数相加*/
    int i,n,a;
    f1=f2=1;/*第一个月和第二个月兔子数相同*/
    scanf("%d",&n);
    a=2;
    for(i=1;i<=n-a;i++,a++)  /*这是它循环多少次的问题,第N个月兔子总数就是前两个兔子总数相加*/
    {

         f3=f1+f2;/*前两个月加起来赋值给第三个月*/

         f1=f2+f3;/*前两个月加起来赋值给第三个月*/

         f2=f3+f1;

    }
         printf("第%d个月兔子总数为%d\n",n,f3);
         printf("第%d个月的后一个月兔子总数为%d\n",n,f1);
         printf("第%d个月的后两个月兔子总数为%d\n",n,f2);
    
    //getchar();
    system("pause");
    
}

这里是我遇到过的一些问题

error C3872: “0x3000”: 此字符不允许在标识符中使用错误 的解决办法

 

主要是拷贝的程序问题,有错误的空字符

0x3000是汉语的空格,也就是全角空格,相当于一个汉字,但你又看不见它。

你知道的,像逗号,有半角(,)和全角(,)之分的,其实空格也有。
0x3000是全角的空格,0x20是半角的空格。

最好把这个语句的后面空白部分,都删除掉,免得有不可见的全角空格。

这里关于全角半角的区分那么全/半角的区别,用通俗的话来讲仅仅区别仅在于除汉字以外的其它字符(比如标点符号、字母、数字等)占用位置的大小,在计算机屏幕上,一个汉字要占两个英文字符的位置,人们把一个英文字符所占的位置称为"半角",相对地把一个汉字所占的位置称为"全角"。在汉字输入时,系统提供"半角"和"全角"两种不同的输入状态,但是对于英文字母、符号和数字等这些通用字符就不同于汉字,在半角状态它们被作为英文字符处理;而在全角状态,它们又可作为中文字符处理。

所以说你在写中文的时候应该用全角好一些,因为这样对于文章能整齐,美观。

当然了,全角和半角还有更专业的区别,比如计算码制不同等等


printf专题:你可能不知道的printf用法

首先,以下四种printf的用法想必大家都应该很熟悉。

 

 

printf函数称为格式输出函数,其关键字最末一个字母f即为“格式”(format)之意。其功能是按用户指定的格式,把指定的数据显示到显示器屏幕上。

 

printf函数调用的一般形式

printf函数是一个标准库函数,它的函数原型在头文件“stdio.h”中。但作为一个特例,不要求在使用 printf 函数之前必须包含stdio.h文件。printf函数调用的一般形式为:
    printf(“格式控制字符串”, 输出表列)
其中格式控制字符串用于指定输出格式。格式控制串可由格式字符串和非格式字符串两种组成。格式字符串是以%开头的字符串,在%后面跟有各种格式字符,以说明输出数据的类型、形式、长度、小数位数等。如:
  • “%d”表示按十进制整型输出;
  • “%ld”表示按十进制长整型输出;
  • “%c”表示按字符型输出等。
非格式字符串原样输出,在显示中起提示作用。输出表列中给出了各个输出项,要求格式字符串和各输出项在数量和类型上应该一一对应。

 

 

格式字符串

1) 类型
类型字符用以表示输出数据的类型,其格式符和意义如下表所示:
格式字符意义
d以十进制形式输出带符号整数(正数不输出符号)
o以八进制形式输出无符号整数(不输出前缀0)
x,X以十六进制形式输出无符号整数(不输出前缀Ox)
u以十进制形式输出无符号整数
f以小数形式输出单、双精度实数
e,E以指数形式输出单、双精度实数
g,G以%f或%e中较短的输出宽度输出单、双精度实数
c输出单个字符
s输出字符串
 
2) 标志
标志字符为 -、+、# 和空格四种,其意义下表所示:
标 志意义
-结果左对齐,右边填空格
+输出符号(正号或负号)
空格输出值为正时冠以空格,为负时冠以负号
#对c、s、d、u类无影响;
对o类,在输出时加前缀o;
对x类,在输出时加前缀0x;
对e、g、f 类当结果有小数时才给出小数点。

3) 输出最小宽度
用十进制整数来表示输出的最少位数。若实际位数多于定义的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或0。

4) 精度
精度格式符以“.”开头,后跟十进制整数。本项的意义是:如果输出数字,则表示小数的位数;如果输出的是字符,则表示输出字符的个数;若实际位数大于所定义的精度数,则截去超过的部分。

5) 长度
长度格式符为h、l两种,h表示按短整型量输出,l表示按长整型量输出。

 

#include<stdio.h> 
#include<string.h> 
int main() 

char c, s[20]; 
int a=1234;
float f=3.141592653589; 
double x=0.12345678912345678; 
strcpy(s, "Hello,World"); 
c='\x41'; 
printf("a=%d\n", a);//按照十进制整数格式输出,显示 a=1234
printf("a=%d%%\n", a);//输出%号 结果 a=1234%
printf("a=%6d\n", a);//输出6位十进制整数 左边补空格,显示 a= 1234
printf("a=%06d\n", a);//输出6位十进制整数 左边补0,显示 a=001234
printf("a=%2d\n", a);//a超过2位,按实际输出 a=1234
printf("a=%-6d\n", a);///输出6位十进制整数 右边补空格,显示 a=1234
printf("f=%f\n", f);//浮点数有效数字是7位,结果 f=3.141593
printf("f=6.4f\n", f);//输出6列,小数点后4位,结果 f=3.1416
printf("x=%lf\n", x);//输出长浮点数 x=0.123457
printf("x=%18.16lf\n", x);//输出18列,小数点后16位,x=0.1234567891234567
printf("c=%c\n", c);     //输出字符 c=A
printf("c=%x\n", c);//以十六进制输出字符的ASCII码 c=41
printf("s[]=%s\n", s);//输出数组字符串s[]=Hello,World
printf("s[]=%6.9s\n", s);//输出最多9个字符的字符串 s[]=Hello,Wor
return 0;
}

 

怎么样,大家学会了吗?

 

*号的用法

*在printf里可以代表一个泛整数,可以代表任何整数。它可以出现在位宽的位置,也可以出现在小数位数的位置。

但在printf的双引号外面,必须要有*对应的数值。

1.转换说明符
      %a(%A)     浮点数、十六进制数字和p-(P-)记数法(C99)
      %c             字符
      %d             有符号十进制整数
      %f              浮点数(包括float和doulbe)
      %e(%E)     浮点数指数输出[e-(E-)记数法]
      %g(%G)     浮点数不显无意义的零"0"
      %i              有符号十进制整数(与%d相同)
      %u             无符号十进制整数
      %o             八进制整数    e.g.     0123
      %x(%X)      十六进制整数<?xml:namespace prefix = st1 />()   e.g.   0x1234
      %p             指针
      %s             字符串
      %%            "%"

2.标志
      左对齐:"-"   e.g.   "%-20s"
      右对齐:"+" e.g.   "%+20s"
      空格:若符号为正,则显示空格,负则显示"-"   e.g.   "% "      
      #:对c,s,d,u类无影响;对o类,在输出时加前缀o;对x类,在输出时加前缀0x;
           对e,g,f 类当结果有小数时才给出小数点。

3.格式字符串(格式)
      [标志][输出最少宽度][.精度][长度]类型 
     "%-md" :左对齐,若m比实际少时,按实际输出。
     "%m.ns":输出m位,取字符串(左起)n位,左补空格,当n>m or m省略时m=n
                      e.g.    "%7.2s"   输入CHINA
                                             输出"     CH"
     "%m.nf":输出浮点数,m为宽度,n为小数点右边数位
                      e.g.    "%"    输入3852.99
                                               输出3853.0 
      长度:为h短整形量,l为长整形量

printf的格式控制的完整格式:
% - .n l或h 格式字符
下面对组成格式说明的各项加以说明:
①%:表示格式说明的起始符号,不可缺少。
②-:有-表示左对齐输出,如省略表示右对齐输出。
③0:有0表示指定空位填0,如省略表示指定空位不填。
④m.n:m指域宽,即对应的输出项在输出设备上所占的字符数。N指精度。用于说明输出的实型数的小数位数。为指定n时,隐含的精度为n=6位。
⑤l或h:l对整型指long型,对实型指double型。h用于将整型的格式字符修正为short型。

 

一个h表示short,即short int

两个h表示short short,即 char。
%hhx用于输出char
%hx用于输出short int.

 

 

---------------------------------------
格式字符 
格式字符用以指定输出项的数据类型和输出格式。
①d格式:用来输出十进制整数。有以下几种用法:
%d:按整型数据的实际长度输出。
%md:m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。
%ld:输出长整型数据。
②o格式:以无符号八进制形式输出整数。对长整型可以用"%lo"格式输出。同样也可以指定字段宽度用“%mo”格式输出。
例:
   main()
   { int a = -1;
     printf("%d, %o", a, a);
   }
运行结果:-1,177777
程序解析:-1在内存单元中(以补码形式存放)为(1111111111111111)2,转换为八进制数为(177777)8。
③x格式:以无符号十六进制形式输出整数。对长整型可以用"%lx"格式输出。同样也可以指定字段宽度用"%mx"格式输出。
④u格式:以无符号十进制形式输出整数。对长整型可以用"%lu"格式输出。同样也可以指定字段宽度用“%mu”格式输出。
⑤c格式:输出一个字符。
⑥s格式:用来输出一个串。有几中用法
%s:例如:printf("%s", "CHINA")输出"CHINA"字符串(不包括双引号)。
%ms:输出的字符串占m列,如字符串本身长度大于m,则突破获m的限制,将字符串全部输出。若串长小于m,则左补空格。
%-ms:如果串长小于m,则在m列范围内,字符串向左靠,右补空格。
%m.ns:输出占m列,但只取字符串中左端n个字符。这n个字符输出在m列的右侧,左补空格。
%-m.ns:其中m、n含义同上,n个字符输出在m列范围的左侧,右补空格。如果n>m,则自动取n值,即保证n个字符正常输出。
⑦f格式:用来输出实数(包括单、双精度),以小数形式输出。有以下几种用法:
%f:不指定宽度,整数部分全部输出并输出6位小数。
%m.nf:输出共占m列,其中有n位小数,如数值宽度小于m左端补空格。 
%-m.nf:输出共占n列,其中有n位小数,如数值宽度小于m右端补空格。
⑧e格式:以指数形式输出实数。可用以下形式:
%e:数字部分(又称尾数)输出6位小数,指数部分占5位或4位。
%m.ne和%-m.ne:m、n和”-”字符含义与前相同。此处n指数据的数字部分的小数位数,m表示整个输出数据所占的宽度。
⑨g格式:自动选f格式或e格式中较短的一种输出,且不输出无意义的零。

---------------------------------------
关于printf函数的进一步说明:
如果想输出字符"%",则应该在“格式控制”字符串中用连续两个%表示,如:
printf("%f%%", 1.0/3);
输出0.333333%。

---------------------------------------
对于单精度数,使用%f格式符输出时,仅前7位是有效数字,小数6位.
对于双精度数,使用%lf格式符输出时,前16位是有效数字,小数6位.

######################################拾遗 ########################################
由高手指点
对于m.n的格式还可以用如下方法表示(例)
char ch[20];
printf("%*.*s\n",m,n,ch);
前边的*定义的是总的宽度,后边的定义的是输出的个数。分别对应外面的参数m和n 。我想这种方法的好处是可以在语句之外对参数m和n赋值,从而控制输出格式。 
--------------------------------------------------------------------------------
今天()又看到一种输出格式 %n 可以将所输出字符串的长度值赋绐一个变量, 见下例:

int slen;

printf("hello world%n", &slen);

执行后变量被赋值为11

 

 

 

另外:

1、格式输出函数的一般形式

      函数原型: int printf(char * format[,argument,…]);

      函数功能:按规定格式向输出设备(一般为显示器)输出数据,并返回实际输出的字符数,若出错,则返回负数。

      它使用的一般形式为:

               printf("格式控制字符串",输出项列表);

      语句中“输出项列表”列出要输出的表达式(如常量、变量、运算符表达式、函数返回值等),它可以是0个、一个或多个,每个输出项之间用逗号(,)分隔。输出的数据可以是整数、实数、字符和字符串。

      "格式控制字符串"必须用英文的双引号括起来,它的作用是 控制输出项的格式和输出一些提示信息,例如

                    int i=97; printf("i=%d,%c\n",i,i);

                输出结果为:i=97,a

        语句“printf("i=%d,%c\n",i,i);”中的两个输出项都是变量i,但却以不同的格式输出,一个输出整型数97,另一个输出的却是字符a,其格式分别由“%d”与“%c”来控制。

        语句“printf("i=%d,%c\n",i,i);”的格式控制字符串中“i=”是普通字符,他将照原样输出;“%d”与“%c”是格式控制符;"\n"是转义字符,它的作用是换行。

2、格式控制

      格式控制由格式控制字符串实现。格式控制字符串由3部分组成:普通字符、转义字符、输出项格式说明。

      (1)普通字符。普通字符在输出时,按原样输出,主要用于输出提示信息。

      (2)转义字符。转义字符指明特定的操作,如"\n"表示换行,"\t"表示水平制表等。

      (3)格式说明部分由“%”和“格式字符串”组成,他表示按规定的格式输出数据。

        格式说明的形式为:

               %[flags][width][.prec][F|N|h|I][type]

        各部分说明如下:

  1. “[]”表示该项为可选项,即可有可无,如 printf("%d",100);
  2. flags为可选择的标志字符,常用的标志字符有:
    •  -   ——左对齐输出,默认为右对齐输出;
    • +   ——正数输出加号(+),负数输出减号(-);
    • 空格 ——正数输出空格代替加号(+),负数输出减号(-)。
  3. width为可选择的宽度指示符。
    • 用十进制正整数表示设置输出值得最少字符个数。不足则补空格,多出则按实际输出,默认按实际输出,例如:
    • printf("%8d\n",100);       printf("%6d\n",100);       printf("%-8d\n",100);        printf("%+8\n",100);
    • 输出结果为:└┘└┘└┘└┘└┘100         
      └┘└┘└┘100          100└┘└┘└┘└┘└┘     └┘└┘└┘└┘+100
  4. [.prec]为可选的精度指示符
    • 用“小数点”加“十进制正整数”表示,对“整数”、“实数”和“字符串”的输出有如下功能:对“整数”,表示至少要输出的数字个数,不足补数字0,多则原样输出;对“实数”,表示小数点后至多输出的数字个数,不足则补数字0,多则做舍入处理;对“字符串”,表示最多输出的字符个数,不足补空格,多则丢弃。
    • 例如:printf("%8.2f\n",3.14159);                     
      printf("%8.5f\n",3.14159);
    • 输出结果为:└┘└┘└┘└┘3.14                                
      └┘3.14159
  5. [F|N|h|I]为可选的输出长度修饰符,其功能如下:
    • F ——输出远指针存放的地址;
    • N——输出近指针存放的地址;
    • h——输出短整型数据的值;
    • l——输出长整型或双精度型数据的值。
    • 例如:long  n=40000;
    •             printf("%8ld\n",n);/*因为200*200是长整型数据*/
  6. type为可选的格式字符,用来进行格式转换。

printf的返回值为一个整数类型,是打印的字符个数,而并非几个数字、几个字符。和位宽的概念一致,比如

 

为什么是4321呢,让我们来解读一下

 

首先,提示一下,要知道printf是有返回值的。

 

第一步:输出43,没有异议吧,因为执行第一个printf的过程中,有要调用第二个、第三个printf,直到第三个printf的43输出

第二步:43输出后,第二个printf之所以输出2,是不是因为第三个printf返回值为“2”呢?让我们继续往下走

第三部:2输出后,第一个printf又输出个1,是不是表明第二个printf返回值为“1”呢?

 

由此我们可以发现,printf是有返回值的,那返回值是什么呢?

 

返回值是输出的长度!

 

首先,第三个printf输出43 。返回输出的长度“2”;

然后,第二个printf输出2。返回输出长度"1";

最后输出1

 

 
 
 

 

为什么vs2010运行c语言程序时刚在运行窗口输入数据,没有出结果,就突然退出了运行窗口

源程序为

#include <math.h>
#include <stdio.h>
int main(void)
{
int a;
int b;
int c;
double x1;
double x2;
double delta;
printf ("请输入一元二次函数a*x*x+b*x+c=0的三个正整系数a,b,c:\n");
scanf_s ("%d%d%d",&a,&b,&c);
delta = b*b - 4*a*c;
if( delta > 0 )
{
x1 = (-b + sqrt(delta)) / (2*a);
x2 = (-b - sqrt(delta)) / (2*a);
printf ("该一元二次方程有两解:x1=%f,x2=%f",x1,x2);
}
else 
{ if ( delta = 0 )
{
x1 = (-b) / (2*a);
x2 = x1;
printf ("该一元二次方程有唯一相同的解:x1=x2=%f",x1); 

else 

printf ("该一元二次方程无解:"); 
}
}
getchar();
return 0;
}
能弹出运行窗口,但是等输完三个数后就马上关闭了,没有出任何结果

 

答:将最后getchar换成system("pause")并且include <stdlib.h>

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
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
int main(void)
{
    int a;
    int b;
    int c;
    double x1;
    double x2;
    double  delta;
    printf("请输入一元二次函数a*x*x+b*x+c=0的三个正整系数a,b,c:\n");
    scanf_s("%d%d%d", &a, &b, &c);
    delta = b*b - 4 * a*c;
    if (delta > 0)
    {
        x1 = (-b + sqrt(delta)) / (2 * a);
        x2 = (-b - sqrt(delta)) / (2 * a);
        printf("该一元二次方程有两解:x1=%f,x2=%f", x1, x2);
    }
    else
    {
        if (delta = 0)
        {
            x1 = (-b) / (2 * a);
            x2 = x1;
            printf("该一元二次方程有唯一相同的解:x1=x2=%f", x1);
        }
        else
        {
            printf("该一元二次方程无解:");
        }
    }
    system("pause");
    return 0;
}
 
追问
为题已解决,谢谢,就是为什么getchar()不行啊?
 
追答
行末有个回车,被getchar读到了
 
追问
好的,谢谢了

上一篇:说说SPI协议

下一篇:IIC协议

联系方式0755-82591179

传真:0755-82591176

邮箱:vicky@yingtexin.net

地址:深圳市龙华区民治街道民治大道973万众润丰创业园A栋2楼A08

Baidu
map