- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
#include <iostream>
using namespace std;
struct list
{
char name[20];
int age;
double height;
list *next;
};
list *first = NULL, *current;
int optn = 0;
void currentfor()
{
if (current->next == NULL)
cout << "List has ended!" << endl;
else
current = current->next;
}
void currentbac()
{
if (current == first)
cout << "This is the beginning of the list." << endl;
else
{
list *previous;
previous = first;
while (previous->next != current)
{
previous = previous->next;
}
current = previous;
}
}
void addbeginning()
{
list *newlist;
newlist = new list;
cout << "Enter your name:" ;
cin >> newlist->name;
cout << "Enter your age:" ;
cin >> newlist->age;
cout << "Enter your height:" ;
cin >> newlist->height;
newlist->next=first;
first=newlist;
}
void addending()
{
list *newlist, *newlist2;
newlist = new list;
cout << "Enter your name: ";
cin >> newlist->name;
cout << "Enter your age : ";
cin >> newlist->age;
cout << "Enter your height : ";
cin >> newlist->height;
newlist->next = NULL;
if (first == NULL)
{
first = newlist;
current=first;
}
else
{
newlist2 = first;
while (newlist2->next != NULL)
{
newlist2 = newlist2->next;
}
newlist2->next = newlist;
}
}
void addmiddle()
{
if ( current->next=NULL)
addending();
else
{
list *newlist;
newlist=new list;
cout << "Enter your name:" ;
cin >> newlist->name;
cout << "Enter your age:" ;
cin >> newlist->age;
cout << "Enter your height:" ;
cin >> newlist->height;
newlist->next=current->next;
current->next=newlist;
}
}
void deletebegin()
{
list *newlist;
newlist = first;
first = first->next;
delete newlist;
}
void deletemiddle()
{
if ( current->next=NULL)
cout<<"There is no one after this.";
else
{
list *newlist;
newlist=current;
current=current->next;
delete newlist;
}
}
void deleteend()
{
list *newlist, *newlist2;
if (first == NULL)
cout << "End of list" << endl;
else
{
newlist = first;
if (newlist->next == NULL)
{
delete newlist;
first = NULL;
}
else
{
while (newlist->next != NULL)
{
newlist2 = newlist;
newlist = newlist->next;
}
delete newlist;
newlist2->next = NULL;
}
}
}
void display()
{
list *newlist;
newlist = first;
cout << endl;
do
{
if (newlist == NULL)
cout << "End of List" << endl;
else
{
cout << "Name is: " << newlist->name << " ";
cout << "Age is: " << newlist->age << " ";
cout << "Height is: " << newlist->height;
cout<<" <-- Current position ";
cout<< endl;
newlist = newlist->next;
}
}
while (newlist!=NULL);
cout << "End of list" << endl;
}
int main()
{
first = NULL;
do
{
display();
cout << endl;
cout << "Choose an option: " << endl;
cout << "1. Move the current position forward once." << endl;
cout << "2. Move the current position backwards once." << endl;
cout << "3. Add a member at the beginning of the list." << endl;
cout << "4. Add a member at the current position of the list." << endl;
cout << "5. Add a member at the ending of the list." << endl;
cout << "6. Delete the first member from the list." << endl;
cout << "7. Delete the member at current position from the list." << endl;
cout << "8. Delete the last member from the list." << endl;
cout << "9. End program." << endl;
cout << endl << " >> " ;
cin >> optn;
switch (optn)
{
case 1 : currentfor();
break;
case 2 : currentbac();
break;
case 3 : addbeginning();
break;
case 4 : addmiddle();
break;
case 5 : addending();
break;
case 6 : deletebegin();
break;
case 7 : deletemiddle();
break;
case 8 : deleteend();
break;
}
}
while (optn!= 9);
}
我执行了这个程序,第 3 个程序工作了。但其他程序似乎使我的程序崩溃了:(有人可以告诉我正确的编码吗?我正在制作一个链接列表,其中的节点填充了名称高度和年龄,它应该适用于任何用户。我应该正确显示整个列表吗?或者链表不是那样显示的吗?好心人可以帮忙吗?
最佳答案
我修正了你的程序,并在评论中指出了你应该注意的所有错误。请好好看看它们,看看自己做错了什么,以便从中吸取教训。
#include <iostream>
using namespace std;
struct list {
char name[20];
int age;
double height;
list *next;
};
list *first = NULL, *current = NULL; // Init current to NULL so you can test whether current is set at all
int optn = 0;
void currentfor() {
if(current == NULL) {
cout << "You don't have any members yet!" << endl;
} else {
if (current->next == NULL)
cout << "This is the end of the list." << endl;
else
current = current->next;
}
}
void currentbac() {
if (current == first)
cout << "This is the beginning of the list." << endl;
else {
list *previous;
previous = first;
while (previous->next != current) {
previous = previous->next;
}
current = previous;
}
}
void addbeginning() {
list *newlist;
newlist = new list;
cout << "Enter your name:" ;
cin >> newlist->name;
cout << "Enter your age:" ;
cin >> newlist->age;
cout << "Enter your height:" ;
cin >> newlist->height;
newlist->next = first;
first = newlist;
if(current == NULL) // Set the current pointer to first, because this is the first element you add
current = first;
}
void addending() {
list *newlist, *newlist2;
newlist = new list;
cout << "Enter your name: ";
cin >> newlist->name;
cout << "Enter your age : ";
cin >> newlist->age;
cout << "Enter your height : ";
cin >> newlist->height;
newlist->next = NULL;
if (first == NULL) {
first = newlist;
current=first;
} else {
newlist2 = first;
while (newlist2->next != NULL) {
newlist2 = newlist2->next;
}
newlist2->next = newlist;
}
}
void addmiddle() {
if (current->next == NULL) // You were assigning here. Use == instead of = or you will assign NULL to
// current->next! Which is incorrect.
addending();
else {
list *newlist;
newlist = new list;
cout << "Enter your name:" ;
cin >> newlist->name;
cout << "Enter your age:" ;
cin >> newlist->age;
cout << "Enter your height:" ;
cin >> newlist->height;
newlist->next = current->next;
current->next = newlist;
}
}
void deletebegin() {
list *newlist;
newlist = first;
first = first->next;
// You need to update the current pointer first
if(newlist == current) {
current = current->next;
}
delete newlist;
}
void deletemiddle() {
list *newlist;
newlist = first;
// If we delete the first element
if(current == first) {
list *deleteMe = first;
first = first->next;
delete deleteMe;
current = current->next;
} else { // Otherwise
// Search until newlist->next == current
// Als test for newlist != NULL or you will try to get a next value from NULL -> crash!
while(newlist != NULL && newlist->next != current)
newlist = newlist->next;
if(newlist != NULL) {
delete newlist->next;
newlist->next = current->next; // Also update the next from the previous node in the list! Or it will not disappear when displaying
if (current->next == NULL) // You did it again here. Use == for comparing values instead of =
current = first; // It doesn't mean that you don't have to delete if
// you don't have a current->next. If you don't have a current->next,
// just set it to first. The element does need to be deleted.
else
current = current->next;
}
}
}
void deleteend() {
list *newlist, *newlist2;
if (first == NULL)
cout << "End of list" << endl;
else {
newlist = first;
if (newlist->next == NULL) {
delete newlist;
first = NULL;
current = NULL; // Current should also be null
} else {
while (newlist->next != NULL) {
newlist2 = newlist;
newlist = newlist->next;
}
delete newlist;
newlist2->next = NULL;
current = newlist2; // You forgot to update the current pointer.
}
}
}
void display() {
list *newlist;
newlist = first;
cout << endl;
do {
if (newlist == NULL)
cout << "End of List" << endl;
else
{
cout << "Name is: " << newlist->name << " ";
cout << "Age is: " << newlist->age << " ";
cout << "Height is: " << newlist->height;
if(current == newlist) // You need to check whether you really are at the current position
cout<<" <-- Current position ";
cout<< endl;
newlist = newlist->next;
}
}
while(newlist!=NULL);
if(newlist != NULL) // What if the newList was initially NULL? You will print twice.
cout << "End of list" << endl;
}
int main(void) {
first=NULL;
do {
display();
cout << endl;
cout << "Choose an option: " << endl;
cout << "1. Move the current position forward once." << endl;
cout << "2. Move the current position backwards once." << endl;
cout << "3. Add a member at the beginning of the list." << endl;
cout << "4. Add a member at the current position of the list." << endl;
cout << "5. Add a member at the ending of the list." << endl;
cout << "6. Delete the first member from the list." << endl;
cout << "7. Delete the member at current position from the list." << endl;
cout << "8. Delete the last member from the list." << endl;
cout << "9. End program." << endl;
cout << endl << " >> " ;
cin >> optn;
switch (optn) {
case 1 : currentfor();
break;
case 2 : currentbac();
break;
case 3 : addbeginning();
break;
case 4 : addmiddle();
break;
case 5 : addending();
break;
case 6 : deletebegin();
break;
case 7 : deletemiddle();
break;
case 8 : deleteend();
break;
}
}
while (optn!= 9);
}
关于C++编程主要帮助需要链接列表我只是看不到我的错误在哪里,尽管它正在运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5127500/
我正在尝试打印 timeval 类型的值。实际上我可以打印它,但我收到以下警告: 该行有多个标记 格式“%ld”需要“long int”类型,但参数 2 的类型为“struct timeval” 程序
我正在编写自己的 unix 终端,但在执行命令时遇到问题: 首先,我获取用户输入并将其存储到缓冲区中,然后我将单词分开并将它们存储到我的 argv[] 数组中。IE命令是“firefox”以启动存储在
我是 CUDA 的新手。我有一个关于一个简单程序的问题,希望有人能注意到我的错误。 __global__ void ADD(float* A, float* B, float* C) { con
我有一个关于 C 语言 CGI 编程的一般性问题。 我使用嵌入式 Web 服务器来处理 Web 界面。为此,我在服务器中存储了一个 HTML 文件。在此 HTML 文件中包含 JavaScript 和
**摘要:**在代码的世界中,是存在很多艺术般的写法,这可能也是部分程序员追求编程这项事业的内在动力。 本文分享自华为云社区《【云驻共创】用4种代码中的艺术试图唤回你对编程的兴趣》,作者: break
我有一个函数,它的任务是在父对象中创建一个变量。我想要的是让函数在调用它的级别创建变量。 createVariable testFunc() [1] "test" > testFunc2() [1]
以下代码用于将多个连续的空格替换为1个空格。虽然我设法做到了,但我对花括号的使用感到困惑。 这个实际上运行良好: #include #include int main() { int ch, la
我正在尝试将文件写入磁盘,然后自动重新编译。不幸的是,某事似乎不起作用,我收到一条我还不明白的错误消息(我是 C 初学者 :-)。如果我手动编译生成的 hello.c,一切正常吗?! #include
如何将指针值传递给结构数组; 例如,在 txt 上我有这个: John Doe;xxxx@hotmail.com;214425532; 我的代码: typedef struct Person{
我尝试编写一些代码来检索 objectID,结果是 2B-06-01-04-01-82-31-01-03-01-01 . 这个值不正确吗? // Send a SysObjectId SNMP req
您好,提前感谢您的帮助, (请注意评论部分以获得更多见解:即,以下示例中的成本列已添加到此问题中;西蒙提供了一个很好的答案,但成本列本身并未出现在他的数据响应中,尽管他提供的功能与成本列一起使用) 我
我想知道是否有人能够提出一些解决非线性优化问题的软件包的方法,而非线性优化问题可以为优化解决方案提供整数变量?问题是使具有相等约束的函数最小化,该函数受某些上下边界约束的约束。 我已经在R中使用了'n
我是 R 编程的初学者,正在尝试向具有 50 列的矩阵添加一个额外的列。这个新列将是该行中前 10 个值的平均值。 randomMatrix <- generateMatrix(1,5000,100,
我在《K&R II C 编程 ANSI C》一书中读到,“>>”和“0; nwords--) sum += *buf++; sum = (sum >>
当下拉列表的选择发生变化时,我想: 1) 通过 div 在整个网站上显示一些 GUI 阻止覆盖 2)然后处理一些代码 3) 然后隐藏叠加层。 问题是,当我在事件监听器函数中编写此逻辑时,将执行 onC
我正在使用 Clojure 和 RESTEasy 设计 JAX-RS REST 服务器. 据我了解,用 Lisp 系列语言编写的应用程序比用“传统”命令式语言编写的应用程序更多地构建为“特定于领域的语
我目前正在研究一种替代出勤监控系统作为一项举措。目前,我设计的用户表单如下所示: Time Stamp Userform 它的工作原理如下: 员工将选择他/她将使用的时间戳类型:开始时间、超时、第一次
我是一名学生,试图自学编程,从在线资源和像您这样的人那里获得帮助。我在网上找到了一个练习来创建一个小程序来执行此操作: 编写一个程序,读取数字 a 和 b(长整型)并列出 a 和 b 之间有多少个数字
我正在尝试编写一个 shell 程序,给定一个参数,打印程序的名称和参数中的每个奇数词(即,不是偶数词)。但是,我没有得到预期的结果。在跟踪我的程序时,我注意到,尽管奇数词(例如,第 5 个词,5 %
只是想知道是否有任何 Java API 可以让您控制台式机/笔记本电脑外壳上的 LED? 或者,如果不可能,是否有可能? 最佳答案 如果你说的是前面的 LED 指示电源状态和 HDD 繁忙状态,恐怕没
我是一名优秀的程序员,十分优秀!