草庐IT

c++ - 将用户输入从 int[] 转换为 char[][]

coder 2024-02-23 原文

我让这个程序将 int 数组作为输入并使用快速排序对其进行排序,但我想知道,我将如何更改这个程序以将 char[][] 作为输入(字符串数组)并按字母顺序对它们进行排序? 如果只有一个字符串,它可以工作,但我想知道如果有人想要字符串数组怎么办

//following program sorts an array using quicksort alorithm

#include<iostream.h>
#include<conio.h>

void swap(int *a, int *b)   //function to swap elements
{
    int t;
     t = *a;
    *a = *b;
    *b = t;
}

int partition(int arr[], int left, int right)  //function takes last element as pivot and places all smaller elements on left of pivot and greater elements on right
{
    int pivot=arr[right];  //Pivot
    int i= (left-1);      //index of smaller element

    for(int j=left; j<=(right-1); j++)
    {
        if(arr[j]<=pivot)           //if current element is smaller or equal to pivot, theyre swapped
        {
            i++;
            swap(&arr[i], &arr[j]);
        }
    }
    swap(&arr[i+1], &arr[right]);
    return (i+1);
}

void quicksort(int arr[], int left, int right) //left is starting index, right is last index
{
    if(left<right)
    {
        int index=partition(arr,left,right);
        quicksort(arr, left, index-1);      //sort elements before and after partition
        quicksort(arr, index+1, right);
    }
}

void print(int *arr, int size)      //function to print elements in array
{
    for(int i=0; i<size; i++)
    {
        cout<<arr[i]<<" ";
    }
}

int main()
{
    int n;      //to store no. of elements in array
    char ch;   //ch for choice
    do{
        int *arr=NULL;     //dynamic int array
        clrscr();
    cout<<"\nEnter Number of Elements:";
    cin>>n;
    cout<<"\nEnter Elements in Array to be sorted:";
    for(int i=0; i<n; i++)
    {
        cout<<"\nEnter "<<i<<"th element:";
        cin>>arr[i];
    }
    quicksort(arr,0,(n-1));
    cout<<"\nSorted Array= ";
    print(arr,n);
    delete arr;
    cout<<"\nwanna sort again??(y/n):";
    cin>>ch;
    }while(ch=='Y'||ch=='y');
    return 0;
}

最佳答案

代码中的整数版本需要 int *arr = new int[n];分配整数数组。

要用字符串数组做到这一点,声明char **arr = new char*[n];并使用 strdup将 char 数组分配给每个字符串。

您应该能够使用标准 qsort在旧的编译器中,否则使用快速排序的这个修改版本。主要区别在于替换了 if(arr[j]<=pivot){}if(strcmp(arr[j], pivot) <= 0){}

void swap(char* &a, char* &b)
{
    char *t = a;
    a = b;
    b = t;
}

int partition(char** arr, int lo, int hi)
{
    int i = lo - 1;
    for(int j = lo; j < hi - 1; j++)
    {
        if(strcmp(arr[j], arr[hi]) < 0)
        {
            i++;
            swap(arr[i], arr[j]);
        }
    }

    if(strcmp(arr[hi], arr[i + 1]) < 0)
        swap(arr[hi], arr[i + 1]);

    return i + 1;
}

void quicksort(char** arr, int const lo, int const hi)
{
    if(lo < hi)
    {
        int p = partition(arr, lo, hi);
        quicksort(arr, lo, p);
        quicksort(arr, p + 1, hi);
    }
}

void print(char **arr, int size)      
{
    for(int i = 0; i<size; i++)
        cout << arr[i] << ", ";
    cout << "\n";
}

int main()
{
    int n;      
    cout << "Enter Number of Elements: ";
    cin >> n;
    cout << "Enter Elements in Array to be sorted:\n";

    char buf[255];

    char **arr = new char*[n];
    for(int i = 0; i < n; i++)
    {
        cout << "Enter " << i << "th element: ";
        cin >> buf;
        arr[i] = strdup(buf);
    }

    quicksort(arr, 0, (n - 1));
    cout << "Sorted:\n";
    print(arr, n);
    cout << "\n";

    for(int i = 0; i < n; i++)
        free(arr[i]); //<=== edit**
    delete[]arr;

    return 0;
}

编辑 1:已更改 quicksort函数
编辑 2:更改了清理。 strdup必须用 free 清理

关于c++ - 将用户输入从 int[] 转换为 char[][],我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47449707/

有关c++ - 将用户输入从 int[] 转换为 char[][]的更多相关文章

  1. ruby-on-rails - 在 Rails 中将文件大小字符串转换为等效千字节 - 2

    我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,

  2. ruby - 使用 ruby​​ 将 HTML 转换为纯文本并维护结构/格式 - 2

    我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h

  3. ruby - 将数组的内容转换为 int - 2

    我需要读入一个包含数字列表的文件。此代码读取文件并将其放入二维数组中。现在我需要获取数组中所有数字的平均值,但我需要将数组的内容更改为int。有什么想法可以将to_i方法放在哪里吗?ClassTerraindefinitializefile_name@input=IO.readlines(file_name)#readinfile@size=@input[0].to_i@land=[@size]x=1whilex 最佳答案 只需将数组映射为整数:@land边注如果你想得到一条线的平均值,你可以这样做:values=@input[x]

  4. ruby - 将散列转换为嵌套散列 - 2

    这道题是thisquestion的逆题.给定一个散列,每个键都有一个数组,例如{[:a,:b,:c]=>1,[:a,:b,:d]=>2,[:a,:e]=>3,[:f]=>4,}将其转换为嵌套哈希的最佳方法是什么{:a=>{:b=>{:c=>1,:d=>2},:e=>3,},:f=>4,} 最佳答案 这是一个迭代的解决方案,递归的解决方案留给读者作为练习:defconvert(h={})ret={}h.eachdo|k,v|node=retk[0..-2].each{|x|node[x]||={};node=node[x]}node[

  5. ruby-on-rails - 如何优雅地重启 thin + nginx? - 2

    我的瘦服务器配置了nginx,我的ROR应用程序正在它们上运行。在我发布代码更新时运行thinrestart会给我的应用程序带来一些停机时间。我试图弄清楚如何优雅地重启正在运行的Thin实例,但找不到好的解决方案。有没有人能做到这一点? 最佳答案 #Restartjustthethinserverdescribedbythatconfigsudothin-C/etc/thin/mysite.ymlrestartNginx将继续运行并代理请求。如果您将Nginx设置为使用多个上游服务器,例如server{listen80;server

  6. ruby-on-rails - 使用 rails 4 设计而不更新用户 - 2

    我将应用程序升级到Rails4,一切正常。我可以登录并转到我的编辑页面。也更新了观点。使用标准View时,用户会更新。但是当我添加例如字段:name时,它​​不会在表单中更新。使用devise3.1.1和gem'protected_attributes'我需要在设备或数据库上运行某种更新命令吗?我也搜索过这个地方,找到了许多不同的解决方案,但没有一个会更新我的用户字段。我没有添加任何自定义字段。 最佳答案 如果您想允许额外的参数,您可以在ApplicationController中使用beforefilter,因为Rails4将参数

  7. ruby-on-rails - Ruby url 到 html 链接转换 - 2

    我正在使用Rails构建一个简单的聊天应用程序。当用户输入url时,我希望将其输出为html链接(即“url”)。我想知道在Ruby中是否有任何库或众所周知的方法可以做到这一点。如果没有,我有一些不错的正则表达式示例代码可以使用... 最佳答案 查看auto_linkRails提供的辅助方法。这会将所有URL和电子邮件地址变成可点击的链接(htmlanchor标记)。这是文档中的代码示例。auto_link("Gotohttp://www.rubyonrails.organdsayhellotodavid@loudthinking.

  8. ruby-on-rails - 简单的 Ruby on Rails 问题——如何将评论附加到用户和文章? - 2

    我意识到这可能是一个非常基本的问题,但我现在已经花了几天时间回过头来解决这个问题,但出于某种原因,Google就是没有帮助我。(我认为部分问题在于我是一个初学者,我不知道该问什么......)我也看过O'Reilly的RubyCookbook和RailsAPI,但我仍然停留在这个问题上.我找到了一些关于多态关系的信息,但它似乎不是我需要的(尽管如果我错了请告诉我)。我正在尝试调整MichaelHartl'stutorial创建一个包含用户、文章和评论的博客应用程序(不使用脚手架)。我希望评论既属于用户又属于文章。我的主要问题是:我不知道如何将当前文章的ID放入评论Controller。

  9. ruby - RVM "ERROR: Unable to checkout branch ."单用户 - 2

    我在新的Debian6VirtualBoxVM上安装RVM时遇到问题。我已经安装了所有需要的包并使用下载了安装脚本(curl-shttps://rvm.beginrescueend.com/install/rvm)>rvm,但以单个用户身份运行时bashrvm我收到以下错误消息:ERROR:Unabletocheckoutbranch.安装在这里停止,并且(据我所知)没有安装RVM的任何文件。如果我以root身份运行脚本(对于多用户安装),我会收到另一条消息:Successfullycheckedoutbranch''安装程序继续并指示成功,但未添加.rvm目录,甚至在修改我的.bas

  10. ruby-on-rails - 使用 ruby​​ 将多个实例变量转换为散列的更好方法? - 2

    我收到格式为的回复#我需要将其转换为哈希值(针对活跃商家)。目前我正在遍历变量并执行此操作:response.instance_variables.eachdo|r|my_hash.merge!(r.to_s.delete("@").intern=>response.instance_eval(r.to_s.delete("@")))end这有效,它将生成{:first="charlie",:last=>"kelly"},但它似乎有点hacky和不稳定。有更好的方法吗?编辑:我刚刚意识到我可以使用instance_variable_get作为该等式的第二部分,但这仍然是主要问题。

随机推荐