インデックス「i」が偶数の場合とインデックス「i」が奇数の場合の 2 つの配列を生成できる関数があるため、最終的に 2 つの配列になります。偶数の 'i' 配列は W_e と呼ばれ、N 要素で構成され、奇数の 'i' 配列は W_o と呼ばれ、N 要素で構成されます。
Wn=[W_e[0],W_o[0],W_e[1],W_o[1],. ..,W_e[N-1],W_o[N-1]] しかし、私はそれを行う方法がわかりません. ネストされたループを使用しようとしましたが、うまくいきませんでした。私の計算によれば、配列 W_e と W_o は正しく生成されます。エントリを 1 つの配列に結合することはできません。
これは私がこれまでに持っているものです。「double *MakeWpowers(int N);」という問題を引き起こしている関数を呼び出す以外は、メイン関数で何もしていません。これは N>2 で機能することに注意してください。N=1 または N=2 はまだ扱っていません。
どんな助けでも大歓迎です。ありがとうございました!!
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <complex.h>
#define pi 4*atan(1)
double *MakeWpowers(int N);
void print_vector(double *x,int N);
double *make_vector(double *x,int N);
int main(void)
{ int N;
double *Wn;
printf("\n Please enter the size of the NxN matrix:\n");
scanf("%d",&N);
Wn=MakeWpowers(N);
//print_vector(Wn,N);
free(Wn);
return(0);
}
double *MakeWpowers(int N)
{
double *Wn,*W_e,*W_o;
int i,j;
Wn=make_vector(Wn, 2*N);
W_e=make_vector(W_e, N);
W_o=make_vector(W_o, N);
for(i=0;i<=N-1;i++)
{
if(i%2==0)
{
W_e[i]=cos((2*i*pi)/N);
}
else
{
W_o[i]=sin((2*i*pi)/N);
}
}
printf("\nThis is the even vector W_e:\n");
print_vector(W_e, N);
printf("\nThis is the odd vector W_o:\n");
print_vector(W_o, N);
for(j=0;j<2*N;j++)
{
if(j%2==0)
{Wn[j]=W_e[i];}
//++i;}
else
{Wn[j]=W_o[i];}
//++i;}
printf("\nthis is Wn:\n\n");
print_vector(Wn, 2*N);
//Wn[j]=W_o[i];
//j++;
}
return(Wn);
}
void print_vector(double *x,int N)
{
int i;
for (i=0; i<N; i++)
{
printf ("%9.4f \n", x[i]);
}
printf("\n");
}
double *make_vector(double *x,int N)
{ int i;
double xi;
x=(double *)malloc((N)*sizeof(double));
for(i=0;i<N;i++)
{
x[i]=(double)xi;
}
return(x);
}