Alnwicker 2023-04-08 15:43 采纳率: 100%
浏览 13
已结题

关于##include#的问题,如何解决?(语言-c++)

这是洛谷上的数列有序的题,我的代码有问题,请帮我改正并解释一下,谢谢



#include <bits/stdc++.h>
using namespace std;
const int Nmax=107;
struct Node{
    int data;
    int nxt;
}node[Nmax];
int size;
int head;
int main(){
    while(cin>>n>>m){
        if(!n&&!m){
            break;
        }
        int now=head;
        for(int i=0;i<n;i++){
            cin>>x;
            node[node[now].nxt]now.nx=++size;
            node[now.nx].data=x;
            node[now.nx].nxt=-1;
        }
        now=head;
        while(now!=-1){
            if(m>node[now].data){
                ++size;
                node[size].data=m;
                node[size].nxt=size;
                break;
            }
            ++size;
            node[size].data=m;
            node[size].nxt=head;
            head=size;
            now=heas;
            while(now!=-1){
                if(now.nx==-1)
                    cout<<node[now].data<<"\n";
                else
                    cout<<node[now].data<<" ";
                if(now.nx!=-1)
                    now=node[now.nx];
            }
        }
    }
  • 写回答

3条回答 默认 最新

  • 阿里嘎多学长 2023-04-08 18:01
    关注

    以下内容部分参考ChatGPT模型:


    这段代码中出现了一个编译错误,即#include &lt;bits/stdc++.h&gt;,应该改为#include <bits/stdc++.h>,因为&lt;&gt;是HTML中的特殊字符,编译器无法识别。

    另外,代码中还有一些语法错误,比如cin>>n>>m应该改为int n,m; cin>>n>>m;node[node[now].nxt]now.nx=++size;应该改为node[node[now].nxt].nxt=++size;now=heas;应该改为now=head;等等。

    以下是修改后的代码:

    #include <bits/stdc++.h>
    using namespace std;
    const int Nmax=107;
    struct Node{
        int data;
        int nxt;
    }node[Nmax];
    int size;
    int head;
    int main(){
        int n,m,x;
        while(cin>>n>>m){
            if(!n&&!m){
                break;
            }
            int now=head;
            for(int i=0;i<n;i++){
                cin>>x;
                node[node[now].nxt].nxt=++size;
                node[now].nxt=size;
                node[size].data=x;
                node[size].nxt=-1;
            }
            now=head;
            while(now!=-1){
                if(m>node[now].data){
                    ++size;
                    node[size].data=m;
                    node[size].nxt=size;
                    break;
                }
                ++size;
                node[size].data=m;
                node[size].nxt=head;
                head=size;
                now=head;
                while(now!=-1){
                    if(node[now].nxt==-1)
                        cout<<node[now].data<<"\n";
                    else
                        cout<<node[now].data<<" ";
                    if(node[now].nxt!=-1)
                        now=node[node[now].nxt].nxt;
                    else
                        now=-1;
                }
            }
        }
        return 0;
    }
    

    这段代码实现的功能是,读入一个有序链表和一个数m,将m插入到链表中的合适位置,并输出新的链表。


    如果我的建议对您有帮助、请点击采纳、祝您生活愉快

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 4月24日
  • 已采纳回答 4月16日
  • 创建了问题 4月8日

悬赏问题

  • ¥20 测距传感器数据手册i2c
  • ¥15 RPA正常跑,cmd输入cookies跑不出来
  • ¥15 求帮我调试一下freefem代码
  • ¥15 matlab代码解决,怎么运行
  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法