❶ 用c語言編寫一個錄音與回放的程序,能幫幫我么
#include <conio.h>
#include <math.h>
#include <process.h>
#define N 5//N個點
#define T 3 //T次擬合
#define W 1//權函數
#define PRECISION 0.00001
float pow_n(float a,int n)
{
int i;
if(n==0)
return(1);
float res=a;
for(i=1;i<n;i++)
{
res*=a;
}
return(res);
}
void mutiple(float a[][N],float b[][T+1],float c[][T+1])
{
float res=0;
int i,j,k;
for(i=0;i<T+1;i++)
for(j=0;j<T+1;j++)
{
res=0;
for(k=0;k<N;k++)
{
res+=a[i][k]*b[k][j];
c[i][j]=res;
}
}
}
void matrix_trans(float a[][T+1],float b[][N])
{
int i,j;
for(i=0;i<N;i++)
{
for(j=0;j<T+1;j++)
{
b[j][i]=a[i][j];
}
}
}
void init(float x_y[][2],int n)
{
int i;
printf("請輸入%d個已知點:\n",N);
for(i=0;i<n;i++)
{
printf("(x%d y%d):",i,i);
scanf("%f %f",&x_y[i][0],&x_y[i][1]);
}
}
void get_A(float matrix_A[][T+1],float x_y[][2],int n)
{
int i,j;
for(i=0;i<N;i++)
{
for(j=0;j<T+1;j++)
{
matrix_A[i][j]=W*pow_n(x_y[i][0],j);
}
}
}
void print_array(float array[][T+1],int n)
{
int i,j;
for(i=0;i<n;i++)
{
for(j=0;j<T+1;j++)
{
printf("%-g",array[i][j]);
}
printf("\n");
}
}
void convert(float argu[][T+2],int n)
{
int i,j,k,p,t;
float rate,temp;
for(i=1;i<n;i++)
{
for(j=i;j<n;j++)
{
if(argu[i-1][i-1]==0)
{
for(p=i;p<n;p++)
{
if(argu[p][i-1]!=0)
break;
}
if(p==n)
{
printf("方程組無解!\n");
exit(0);
}
for(t=0;t<n+1;t++)
{
temp=argu[i-1][t];
argu[i-1][t]=argu[p][t];
argu[p][t]=temp;
}
}
rate=argu[j][i-1]/argu[i-1][i-1];
for(k=i-1;k<n+1;k++)
{
argu[j][k]-=argu[i-1][k]*rate;
if(fabs(argu[j][k])<=PRECISION)
argu[j][k]=0;
}
}
}
}
void compute(float argu[][T+2],int n,float root[])
{
int i,j;
float temp;
for(i=n-1;i>=0;i--)
{
temp=argu[i][n];
for(j=n-1;j>i;j--)
{
temp-=argu[i][j]*root[j];
}
root[i]=temp/argu[i][i];
}
}
void get_y(float trans_A[][N],float x_y[][2],float y[],int n)
{
int i,j;
float temp;
for(i=0;i<n;i++)
{
temp=0;
for(j=0;j<N;j++)
{
temp+=trans_A[i][j]*x_y[j][1];
}
y[i]=temp;
}
}
void cons_formula(float coef_A[][T+1],float y[],float coef_form[][T+2])
{
int i,j;
for(i=0;i<T+1;i++)
{
for(j=0;j<T+2;j++)
{
if(j==T+1)
coef_form[i][j]=y[i];
else
coef_form[i][j]=coef_A[i][j];
}
}
}
void print_root(float a[],int n)
{
int i,j;
printf("%d個點的%d次擬合的多項式系數為:\n",N,T);
for(i=0;i<n;i++)
{
printf("a[%d]=%g,",i+1,a[i]);
}
printf("\n");
printf("擬合曲線方程為:\ny(x)=%g",a[0]);
for(i=1;i<n;i++)
{
printf(" + %g",a[i]);
for(j=0;j<i;j++)
{
printf("*X");
}
}
printf("\n");
}
void process()
{
float x_y[N][2],matrix_A[N][T+1],trans_A[T+1][N],coef_A[T+1][T+1],coef_formu[T+1][T+2],y[T+1],a[T+1];
init(x_y,N);
get_A(matrix_A,x_y,N);
printf("矩陣A為:\n");
print_array(matrix_A,N);
matrix_trans(matrix_A,trans_A);
mutiple(trans_A,matrix_A,coef_A);
printf("法矩陣為:\n");
print_array(coef_A,T+1);
get_y(trans_A,x_y,y,T+1);
cons_formula(coef_A,y,coef_formu);
convert(coef_formu,T+1);
compute(coef_formu,T+1,a);
print_root(a,T+1);
}
void main()
{
process();
}
]]>
</Content>
<PostDateTime>2007-4-19 19:23:57</PostDateTime>
</Reply>
<Reply>
<PostUserNickName></PostUserNickName>
<rank>一級(初級)</rank>
<ranknum>user1</ranknum>
<credit>100</credit>
<ReplyID>40389872</ReplyID>
<TopicID>5478010</TopicID>
<PostUserId>1526752</PostUserId>
<PostUserName>jiangxc2004</PostUserName>
<Point>0</Point>
<Content>
<![CDATA[
你可以改一下
不從終端輸入,直接在程序中給出參數
請輸入5個已知點:
(x0 y0):-2 -0.1
(x1 y1):-1 0.1
(x2 y2):0 0.4
(x3 y3):1 0.9
(x4 y4):2 1.6
矩陣A為:
1 -2 4 -8
1 -1 1 -1
1 0 0 0
1 1 1 1
1 2 4 8
法矩陣為:
5 0 10 0
0 10 0 34
10 0 34 0
0 34 0 130
5個點的3次擬合的多項式系數為:
a[1]=0.408571, a[2]=0.391667, a[3]=0.0857143, a[4]=0.00833333,
擬合曲線方程為:
y(x)=0.408571 + 0.391667*X + 0.0857143*X*X + 0.00833333*X*X*X
]]>
</Content>
<PostDateTime>2007-4-19 19:26:11</PostDateTime>
</Reply>
<Reply>
<PostUserNickName></PostUserNickName>
<rank>一級(初級)</rank>
<ranknum>user1</ranknum>
<credit>100</credit>
<ReplyID>40390406</ReplyID>
<TopicID>5478010</TopicID>
<PostUserId>1526752</PostUserId>
<PostUserName>jiangxc2004</PostUserName>
<Point>0</Point>
<Content>
<![CDATA[
這樣就可以直接調用process()函數了!
二次擬合的話就把宏 T 成2;
擬合點的數目 N 也可以修改!
也可以去到注釋的部分進行返回值的調用!
另外,團IDC網上有許多產品團購,便宜有口碑
❷ C語言命名規范
寫C/C++程序,特別是寫Windows程序,強烈建議採用匈牙利式函數變數命名法。它的好處是函數變數命名有敘述性,變數類型一目瞭然。具體做法其實很簡單:
函數都是以動詞開頭如Set、Get等,每個英文單詞首字母大寫。以能簡要敘述清楚函數功能為目的,如函數名SetRect、FindCompany、SearchWord、DestroyWindow等。
變數名一般以一個小寫的類型字母後跟名詞或名片語組成,以下是我個人常用的類型字母,僅以舉例:a 數組、b 布爾變數、bt 位元組、c 字元、clr COLORREF、cls CLASS、dbl 雙精度、dw 雙字、f 單精度、h 句柄、i 索引、l 長整型、lp 長指針、lpsz 指向一個字元串的長指針、n 整數、o 對象、p 指針、pt POINT、rc RECT、s CString、sz 空結尾的數組、t 結構、u 無符號整數、ul 無符號長整數、w 字、wnd 窗口。如果是多個名片語組成每個詞首字母也要大寫。此外,如果是全局或結構類等的變數,還有前綴之分。一般全局變數前加g_(如果是全局類或對象個人更喜歡用the命名,如theApp),類成員變數加m_,結構成員也可以加m_,不過為了與類成員區分,如果不是太復雜的結構,也可以不加m_。變數名舉例如變數名nCommand、uLineAddress、wRegister、m_tNode、iIterator等。
❸ c語言如何用系統時間給文件命名精確到毫秒級
GetCurrentTime();//不過達不到你要求的毫秒級
❹ C語言的時間函數
程序似乎有問題,無效數據 輸入什麼都是無效的
❺ 用C語言把當前時間作為txt文本的名稱
調用getdate和gettime函數時應在程序前麵包含命令行:
#include<dos.h>
說明:
(1)在dos.h中已說明struct date結構如下:
struct date
{ int da_year;/*現年*/
char da_day;/*月的日*/
char da_mon;/*月(1=jan)*/
};
(2)在dos.h中說明struct time結構如下:
struct time
{ unsigned char ti_min;/*分*/
unsigned char ti_hour;/*時*/
unsigned char ti_hund;/*百分之一秒*/
unsigned char ti_sec;/*秒*/
};
/*下面是把系統當前日期、時間填入所指結構中的兩個函數原型*/
void getdate(struct date*pdate);
void gettime(struct time*ptime);
以上由hanxuaiztt提供
http://..com/question/8258745.html?fr=qrl
❻ c語言變數名命名規則
在定義變數時,變數名可以是字母、數字和下劃線的組合。但是也不是隨便的組合,要注意以下幾個命名規則:
1、變數名以英文字母開頭;
變數名的開頭不能是數字,可以由字母或下劃線開頭。但,實際上編程中最常用的是以字母開頭,而以下劃線開頭的變數名是系統專用的。
隨便打開一個頭文件就會看到,它裡面所有的變數名、宏名、函數名全是以下劃線開始的。
所以為了避免與系統定義的名字產生沖突,在編程的時候,除非要求這么定義,否則永遠都不要使用下劃線作為一個變數名的開頭。
正確的變數名:
int In_1=2;
int abc=5;
錯誤的變數名:
int 1In_1=2;
int 2abc=5;
2、不可以包含空格、標點符號和類型說明符(%、&、!、#、@、$);
//錯誤的變數名:不能包含空格、標點符號和類型說明符(%、&、!、#、@、$),只能是字母、數字、下劃線組成。
int %age = 13;
int a%ge = 13;
int name age = 12;
3、字母是區分大小寫;
//變數n和變數N是兩個變數。
int n = 11;
int N = 18;
4、有效長度為255個字元;
5、不可以是關鍵字;
//錯誤的變數名:case是C語言的一個關鍵字,不能作為變數名
int case = 12;
C語言中定義的關鍵字有:
由ANSI標準定義的C語言關鍵字共32個:auto、 double、 int、 struct、 break 、else、 long、 switch、case、 enum、 register 、typedef、 char 、extern 、return、 union 、const、 float 、short、 unsigned、 continue、 for、 signed 、void、default 、goto、 sizeof 、volatile、 do 、if 、while、 static。
這32個關鍵字就是已經被C語言本身使用,不能作為其他用途使用,比如不能定義成變數名、函數名。
❼ c語言文件讀寫怎麼讓生成的txt文件名是系統時間
獲取系統的當前時間,然後給一個字元串,然後用這個字元串命名TXT
❽ C語言文件名命名有什麼規則么
C語言文件名命名只要符合標識符命名規則即可,另外,頭文件以".h"為後綴,源文件以".c"為後綴。
C語言標識符命名規則:
標識符由字母(A-Z,a-z)、數字(0-9)、下劃線「_」組成,並且首字元不能是數字,但可以是字母或者下劃線。例如,正確的標識符:abc,a1,prog_to。
不能把C語言關鍵字作為用戶標識符,例如if ,for, while等.
標識符長度是由機器上的編譯系統決定的,一般的限制為8字元(註:8字元長度限制是C89標准,C99標准已經擴充長度,其實大部分工業標准都更長)。
標識符對大小寫敏感,即嚴格區分大小寫。一般對變數名用小寫,符號常量命名用大寫。
標識符命名應做到「見名知意」,例如,長度(外語:length),求和、總計(外語:sum),圓周率(外語:pi)……
❾ C語言標識符的命名規則有哪些
C語言標識符的命名規則有:
1、有效字元:只能由字母、數字和下劃線組成,且以字母或下劃線開頭。
2、有效長度:隨系統而異,但至少前8個字元有效。如果超長,則超長部分被舍棄。
例如,由於student_name和student_number的前8個字元相同,有的系統認為這兩個變數,是一回事而不加區別。在TCV2.0中,變數名(標識符)的有效長度為1~32個字元,預設值為32。
3、C語言的關鍵字不能用作變數名。
(9)c語言錄音時間命名擴展閱讀
C語言標識符使用注意事項
1、標識符由字母(A-Z,a-z)、數字(0-9)、下劃線「_」組成,並且首字元不能是數字,但可以是字母或者下劃線。例如,正確的標識符:abc,a1,prog_to。
2、不能把C語言關鍵字作為用戶標識符,例如if,for,while等。
3、標識符長度是由機器上的編譯系統決定的,一般的限制為8字元(註:8字元長度限制是C89標准,C99標准已經擴充長度,其實大部分工業標准都更長)。
4、標識符對大小寫敏感,即嚴格區分大小寫。一般對變數名用小寫,符號常量命名用大寫。
❿ 用C語言每隔三秒建立一個以日期時間命名的文件
time_tnow;
structtm*curTime;
charfilename[256];
while(1)
{
now=time(NULL);
curTime=localtime(&now);
sprintf(filename,"%04d-%02d-%02d%02d-%02d-%02d",curTime->tm_year+1900,
curTime->tm_mon+1,curTime->tm_mday,curTime->tm_hour,curTime->tm_min,
curTime->tm_sec);
fp=fopen(filename,"w");
fclose(fp);
sleep(3);
}