精品专区-精品自拍9-精品自拍三级乱伦-精品自拍视频-精品自拍视频曝光-精品自拍小视频

網站建設資訊

NEWS

網站建設資訊

c語言編函數程序 c語言函數編寫程序

C語言程序編寫?

#includeiostream

成都創新互聯主要從事成都網站建設、做網站、網頁設計、企業做網站、公司建網站等業務。立足成都服務東莞,十載網站建設經驗,價格優惠、服務專業,歡迎來電咨詢建站服務:028-86922220

#includetypeinfo

using namespace std;

const int PI=3.14;

templatetypename T

class Circle{

private:

T r;

public:

Circle(){r=0;}//無參構造函數

Circle(T x):r(x){}//帶參構造函數

void show()

{

coutrendl;

}

T area()

{

return PI*r*r;

}

};

int main()

{

/******int*****/

Circleint a(3);

a.show();//輸出半徑

couta.area()endl;//輸出面積

/***double***/

Circledouble b(3.2);

b.show();//輸出半徑

coutb.area()endl;//輸出面積

return 0;

}

C語言編程函數

C語言中一個完整的函數由函數首部和函數體構成,而且定義函數時兩者都是必不可少的。

函數定義的一般形式如下:

類型標識符 函數名(形參表列) // 這是函數首部

// 以下{ }內的是函數體

{

說明部分

執行部分

}

舉例說明如下:

// 定義一個不帶返回值的函數

// 函數功能:輸出形參的值

void fun(int a, int b)

{

printf("%d, %d\n", a, b);

}

// 定義一個帶返回值的函數

// 函數功能:返回2個整數數的最大值

int fun(int a, int b)

{

return ab ? a : b;

}

用C語言的函數編寫程序

可以使用窮舉

以半筐魚為1,滿筐魚為2,則每人分魚為7, 最多三個滿筐

在分到n個滿筐后,半筐數為7-n*2 , 空筐數為7-n-(7-n*2)=n

也就是說,滿筐和空筐相等。

#include?stdio.h

int?main()

{

int?a1,b1,a2,b2,a3,b3;

for(a1=0;a1=3;?a1++)

{

b1=7-a1*2;

for(a2=0;a2=3;?a2++)

{

b2=7-a2*2;

if(b20)?continue;

a3=7-a1-a2;

b3=7-b1-b2;

if(a3=0??b3=0)

{

printf("%d?%d?%d\n",?a1,b1,a1);

printf("%d?%d?%d\n",?a2,b2,a2);

printf("%d?%d?%d\n",?a3,b3,a3);

printf("\n");

}

}

}

return?0;????

}

C語言庫函數如何編寫?

/***

*printf.c - print formatted

*

* Copyright (c) 1985-1997, Microsoft Corporation. All rights reserved.

*

*Purpose:

* defines printf() - print formatted data

*

*******************************************************************************/

#include

#include

#include

#include

#include

#include

#include

/***

*int printf(format, ...) - print formatted data

*

*Purpose:

* Prints formatted data on stdout using the format string to

* format data and getting as many arguments as called for

* Uses temporary buffering to improve efficiency.

* _output does the real work here

*

*Entry:

* char *format - format string to control data format/number of arguments

* followed by list of arguments, number and type controlled by

* format string

*

*Exit:

* returns number of characters printed

*

*Exceptions:

*

*******************************************************************************/

int __cdecl printf (

const char *format,

...

)

/*

* stdout ''PRINT'', ''F''ormatted

*/

{

va_list arglist;

int buffing;

int retval;

va_start(arglist, format);

_ASSERTE(format != NULL);//斷言宏。如果輸出格式字符串指針為空,則在DEBUG版下斷言,報告錯誤。

_lock_str2(1, stdout);

buffing = _stbuf(stdout);//stdout:指定輸出到屏幕

retval = _output(stdout,format,arglist);

_ftbuf(buffing, stdout);

_unlock_str2(1, stdout);

return(retval);

}

以上為printf()的源代碼

1、從含有可選參數函數中獲得可選參數,以及操作這些參數

typedef char *va_list;

void va_start( va_list arg_ptr, prev_param );

type va_arg( va_list arg_ptr, type );

void va_end( va_list arg_ptr );

假定函數含有一個必選參數和多個可選參數,必選參數聲明為普通數據類型,且能通過參數名來獲得該變量的值。可選參數通過宏va_start、va_arg和va_end(定義在stdarg.h或varargs.h中)來進行操作,即通過設置指向第一個可選參數指針、返回當前參數、在返回參數后重新設置指針來操作所有的可選參數。

va_start:為獲取可變數目參數的函數的參數提供一種便捷手段。設置arg_ptr為指向傳給函數參數列表中的第一個可選參數的指針,且該參數必須是va_list類型。prev_param是在參數列表中第一個可選參數前的必選參數。

va_arg:返回由arg_ptr所指向的參數的值,且自增指向下一個參數的地址。type為當前參數的類型,用來計算該參數的長度,確定下一個參數的起始位置。它可以在函數中應用多次,直到得到函數的所有參數為止,但必須在宏va_start后面調用。

va_end:在獲取所有的參數后,設置指針arg_ptr為NULL。

下面舉例說明:

#include

#include

int average( int first, ... );

void main( void )

{

/* Call with 3 integers (-1 is used as terminator). */

printf( "Average is: %d\n", average( 2, 3, 4, -1 ) );

/* Call with 4 integers. */

printf( "Average is: %d\n", average( 5, 7, 9, 11, -1 ) );

/* Call with just -1 terminator. */

printf( "Average is: %d\n", average( -1 ) );

}

int average( int first, ... )

{

int count = 0, sum = 0, i = first;

va_list marker;

va_start( marker, first ); /* Initialize variable arguments. */

while( i != -1 )

{

sum += i;

count++;

i = va_arg( marker, int);

}

va_end( marker ); /* Reset variable arguments. */

return( sum ? (sum / count) : 0 );

}

返回值為:

Average is: 3

Average is: 8

Average is: 0

綜上所述,在printf()函數中,可以只輸出一個字符串,也可按照一定的形式輸出含有多個可選參數的字符串信息。因此,首先就要通過這些宏來獲取所有的可選參數。在上面的源碼可以看出printf()中,只使用了宏at_start,將可選參數的首地址賦給了arglist。

2、鎖定字符串及輸出字符串到屏幕

#define _lock_str2(i,s) _lock_file2(i,s)

void __cdecl _lock_file2(int, void *);

#define _unlock_str2(i,s) _unlock_file2(i,s)

void __cdecl _unlock_file2(int, void *);

int __cdecl _stbuf(FILE *);

void __cdecl _ftbuf(int, FILE *);

int __cdecl _output(FILE *, const char *, va_list);

在output函數中,讀取格式字符串中的每一個字符,然后對其進行處理,處理方式根據每一個字符所代表的意義來進行,如:普通字符直接利用函數WRITE_CHAR(ch, charsout);輸出到控制臺。

其中的主要部分是對轉換說明符(d,c,s,f)的處理,現在將對其中的部分代碼進行詳細說明,這里只說明最基本的轉換說明符,對這些須基本的轉換說明符進行修飾的修飾符,程序中單獨進行處理。下面是函數output()(output.c)部分源代碼:

case ST_TYPE:

//表示當前處理的字符的類型為轉換說明符。

...

switch (ch) {

//下面對參數的獲取都是利用宏va_arg( va_list arg_ptr, type );來進行的。

case ''c'': {

//從參數表中獲取單個字符,輸出到緩沖字符串中,此時,type=int

buffer[0] = (char) get_int_arg(argptr); /* get char to print */

text = buffer;

textlen = 1; /* print just a single character */

}

break;

case ''s'': {

//從參數表中獲取字符串,輸出到緩沖字符串中,此時,type=char*

int i;

char *p; /* temps */

text = get_ptr_arg(argptr);

...

}

break;

case ''w'': {

//對寬字符進行處理

...

} /* case ''w'' */

break;

...

case ''e'':

case ''f'':

case ''g'': {

//對浮點數進行操作

...

#if !LONGDOUBLE_IS_DOUBLE

/* do the conversion */

if (flags FL_LONGDOUBLE) {

_cldcvt((LONGDOUBLE*)argptr, text, ch, precision, capexp);

va_arg(argptr, LONGDOUBLE);

//對長雙精度型進行處理,此時,type=long double

}

else

#endif /* !LONGDOUBLE_IS_DOUBLE */

{

//對雙精度型進行處理,此時,type=double

_cfltcvt((DOUBLE*)argptr, text, ch, precision, capexp);

va_arg(argptr, DOUBLE);

}

...

break;

//對整型變量處理

case ''d'':

case ''i'':

...

goto COMMON_INT;

case ''u'':

radix = 10;

goto COMMON_INT;

case ''p'':

...

goto COMMON_INT;

case ''o'':

...

注:對于浮點型double和long double,有相應的轉換說明符(%f表示雙精度型,%lf表示長雙精度型),而float卻沒有。其中的原因是,在KRC下,float值用于表達式或用作參數前,會自動轉換成double類型。而ANSI C一般不會自動把float轉換成double。有些程序已假定其中的float參數會被轉換成double,為了保護大量這樣的程序,所有printf()函數的float參數還是被自動轉換成double型。因此,在KRC或ANSI C下,都無需用特定的轉換說明符來顯示float型。

綜上所述,轉換說明符必須與待打印字符的類型。通常,用戶有種選擇。例如,如要打印一個int類型的值。則只可以使用%d,%x或%o。所有這些說明符都表示要打印一個int類型的值;它們只不過提供了一個數值的幾種不同表示。類似一,可以用%f、%g和%e來表示double類型的值。但如果轉換說明與類型不匹配,將會出現意想不到的結果。為什么呢?問題就在于C向函數傳遞信息的方式。

這個失敗的根本細節與具體實現相關。它決定了系統中的參數以何方式傳遞。函數調用如下:

float n1;

double n2;

long n3;

long n4;

...

printf("%ld,%ld,%ld,%ld",n1,n2,n3,n4);

這個調用告訴計算機,要把變量n1,n2,n3和n4的值交給計算機,它把這些變量放進稱作棧(stack)的內存區域中,來完成這一任務。計算機把這些值放進棧中,其根據是變量的類型而不是轉換說明符,比如n1,把8個字節放入棧中(float被轉換成double),類似地,為n2放了8字節,其后給n3和n4各放了4個字節。接著,控制的對象轉移到printf();此函數從棧中讀數,不過在這一過程中,它是在轉換說明符的指導下,讀取數值的。說明符%ld指定printf()應讀4個字節(va_arg( va_list arg_ptr, type )中type=long),因此printf()讀入棧中的4個字節,作為它的第一個值。但是這只是n1的前半部分,這個值被看成一個long整數。下一個說明符%ld讀入4個字節,這正是n1的后半部分,這個值被看成第二個long整數。類似地,第三、第四次又讀入n2的前后兩部分。因此,盡管我們對n3和n4使用了正確的說明符,printf()仍然會產生錯誤。

c語言編寫函數

思路:用數組操作,將自然數先求出他的長度,再將它換成對應位的權積存入數組中,然后累加得到結果。

#includeiostream

using

namespace

std;

#includemath.h

int

fun(int

n)

{

int

a[10],cnt(1),m(n),k(0);

while(m10)

//while循環求數字的長度,看是幾位數

{

cnt++;

m/=10;

}

for(int

i=0;icnt;i++)

//將每一位和點到循序后的位權乘積存入數組中,并球累加和

{

int

s=pow(10,i+1);

int

t=pow(10,i);

int

r=pow(10,cnt-i-1);

a[i]=(n%s)/t*r;

k+=a[i];

}

return

k;

}

int

main()

{

coutfun(23456);

//用了多組數測試均成功!!!

return

0;

}


本文名稱:c語言編函數程序 c語言函數編寫程序
瀏覽路徑:http://m.jcarcd.cn/article/hhsepj.html
主站蜘蛛池模板: 日韩美女三级视频 | 日本三级国产综合 | 国产福利不 | 日韩AⅤ在线观看 | 91视频免费福利 | 91九色老 | 日韩免费一区 | 成人动漫视频在线 | 国产亚洲成a | 精品免费| 成人一区在线观看 | 国产a级自拍| 欧美日韩在线一本卡 | 国产综合6 | 国产精品高清尿 | 青青草国产精品视频 | 99re这里是国产 | 成人做爰视 | 成人禁在线观看午 | 欧洲在线观看视频高 | 成人精品免费在 | 欧美综合精品久 | 中文字幕在线免费 | 精品97人| 91香蕉八年 | 日韩欧美人兽 | 日韩午夜炮机 | 国产日韩欧美专区 | 国产秘精品入口欧 | 精品熟女碰 | 日韩成人激情综合网 | 91高清在线 | 区三区国产高清视频 | 欧美在线伊人 | 日韩高清精品在线 | 国产乱对白刺激视频 | 成人福利在线 | 精品二区 | 精品乱伦中文国产 | 精品欧美在 | 国产丝袜jk福利 |