検討:
struct Package_Node
{
int bar_code;
float package_weight;
struct Package_Node *next_packaged;
};
struct Key_Node
{
int key;
struct Package_Node *next_package;
};
int weightTemp = 0, barcodeTemp = 0, keyTemp = 0, N = 0, X = 0, max_value = 0, optionChosen = 0, optionChosenTwo = 0;
float tempWeight;
int main()
{
srand(time(NULL));
do
{
cout << "1 - Enter Number of keys and the Max Value\n2 - Enter Number of Packages (N)\n";
cout << "3 - Create Array of Keys\n4 - Organize Packages\n5 - Table Stats\n6 - Clean Table\n7 - Exit\n\n";
cin >> optionChosen;
switch(optionChosen)
{
case 1:
{
cout << "\nEnter Number of Keys:";
cin >>X;
cout <<"\nEnter Max Value of the Barcode: ";
cin >>max_value;
break;
}
case 2:
{
cout << "\nEnter Number of Packages: ";
cin >> N;
//keyTemp=
break;
}
case 3:
{
Key_Node keyMain[X];
for(int i=0;i<X;i++)
{
keyMain[i].key=i;
//cout << keyMain[i].key; //to see key values.
}
break;
}
case 4:
{
Package_Node totalPackages[N];
for(int i=0;i<N;i++)
{
barcodeTemp = rand() % max_value + 1;
keyTemp = barcodeTemp % X;
tempWeight = rand() % 500 + 1;
totalPackages[i].bar_code=barcodeTemp;
totalPackages[i].package_weight=tempWeight;
}
for(int i=0;i<N;i++)
{
cout << totalPackages[i].bar_code <<endl;
cout << totalPackages[i].package_weight << endl;
}
これは私のコードです。合計パッケージ[i](動的配列)の情報を入れて、(Package_Nodeデータ型と静的配列の)keyMainにリンクしようとしています。しかし、私はここでその方法を完全に失いました。
また、動的配列「totalPackages」の宣言は正しいですか? または、ユーザーが入力したパッケージの総数に応じてサイズが大きくなるため、サイズを宣言しないでください。totalPackages
プログラムが望むように成長するリンクされたリストであると想定されています。