4个回答
展开全部
#include <stdio.h>
#include <string.h>
char * findlongword(char * str)
{
char long_word[100];
char temp_word[100];
unsigned int len = 0;
memset(temp_word,0,sizeof(temp_word));
memset(long_word,0,sizeof(long_word));
for(int i=0;i<=strlen(str);i++)
{
if((str[i] != 0x20) && (str[i] != 0x00))
{
temp_word[len++] = str[i];
}
else
{
temp_word[len] = 0x00;
len = 0;
//printf("%s\n",temp_word);
if(strlen(temp_word) >= strlen(long_word))
{
strcpy(long_word,temp_word);
}
}
}
printf("%s\n",long_word);
return long_word;
}
void main()
{
char * str = "我想问下 如何用一个函数实现将一行字符串中 最长的单词输出 此行字符串从主函数传递给该函数";
findlongword(str);
}
#include <string.h>
char * findlongword(char * str)
{
char long_word[100];
char temp_word[100];
unsigned int len = 0;
memset(temp_word,0,sizeof(temp_word));
memset(long_word,0,sizeof(long_word));
for(int i=0;i<=strlen(str);i++)
{
if((str[i] != 0x20) && (str[i] != 0x00))
{
temp_word[len++] = str[i];
}
else
{
temp_word[len] = 0x00;
len = 0;
//printf("%s\n",temp_word);
if(strlen(temp_word) >= strlen(long_word))
{
strcpy(long_word,temp_word);
}
}
}
printf("%s\n",long_word);
return long_word;
}
void main()
{
char * str = "我想问下 如何用一个函数实现将一行字符串中 最长的单词输出 此行字符串从主函数传递给该函数";
findlongword(str);
}
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
import java.util.ArrayList;
import java.util.List;
public class test {
@SuppressWarnings("unchecked")
public List getStr(String str){
List searchList = new ArrayList();
String[] strs = str.split(" ");
for(int i = 0;i < strs.length;i++){
for(int j = 0; j < strs.length;j++){
if(strs[i].length() > strs[j].length()){
String s = strs[j];
strs[j] = strs[i];
strs[i] = s;
}
}
}
int n = 0;
for(int i = 0;i < strs.length;i++){
if(n !=0 && n != strs[i].length()){
break;
}
searchList.add(strs[i]);
n = strs[i].length();
}
return searchList;
}
public static void main(String[] args){
test t = new test();
String str = "how do you do";
List strList = t.getStr(str);
for(int i = 0;i < strList.size();i++){
System.out.println((String)strList.get(i));
}
}
}
测试一下,试试吧
import java.util.List;
public class test {
@SuppressWarnings("unchecked")
public List getStr(String str){
List searchList = new ArrayList();
String[] strs = str.split(" ");
for(int i = 0;i < strs.length;i++){
for(int j = 0; j < strs.length;j++){
if(strs[i].length() > strs[j].length()){
String s = strs[j];
strs[j] = strs[i];
strs[i] = s;
}
}
}
int n = 0;
for(int i = 0;i < strs.length;i++){
if(n !=0 && n != strs[i].length()){
break;
}
searchList.add(strs[i]);
n = strs[i].length();
}
return searchList;
}
public static void main(String[] args){
test t = new test();
String str = "how do you do";
List strList = t.getStr(str);
for(int i = 0;i < strList.size();i++){
System.out.println((String)strList.get(i));
}
}
}
测试一下,试试吧
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
我写的有些复杂 因为很多基础功能 我都没调用函数;
看看吧 有问题找我
#include "stdio.h"
int main()
{
int N,count=0,i,j,k,Max=0,biao=0;
char arry[]="I am your father";
char word[4][8];
int Len[4]={0};
char *t;
t=arry;
while (*t)
{
if (*t == 32)
{
printf("空格\n");
count++;
}
t++;
}
printf("一共有%d个单词\n",count+1);
N = count+1;
k=0;
for (i=0;i<N;i++)
{
for (j=0;j<15;j++)
{
if ( arry[k] ==32)
{
k++;
word[i][j] ='\0';
break;
}
else
{
word[i][j] = arry[k];
}
k++;
}
}
for (i=0;i<4;i++)
{
t = word[i];
while (*t)
{
printf("%c",*t);
t++;
}
printf("\n");
}
for (i=0;i<4;i++)
{
t = word[i];
while (*t)
{
t++;
Max++;
}
Len[i]=Max;
printf("%d \n",Max);
Max =0;
}
printf("OK\n");
Max=Len[0];
for(i=0;i<4;i++)
{
if(Max<Len[i])
{
Max = Len[i];
biao = i;
}
}
printf("最大值:%d,下标为:%d\n",Max,biao);
printf("即第%d个单词:",biao+1);
for (i=0;i<6;i++)
{
printf("%c",word[3][i]);
}
printf(" 最长。\n");
return 0;
}
看看吧 有问题找我
#include "stdio.h"
int main()
{
int N,count=0,i,j,k,Max=0,biao=0;
char arry[]="I am your father";
char word[4][8];
int Len[4]={0};
char *t;
t=arry;
while (*t)
{
if (*t == 32)
{
printf("空格\n");
count++;
}
t++;
}
printf("一共有%d个单词\n",count+1);
N = count+1;
k=0;
for (i=0;i<N;i++)
{
for (j=0;j<15;j++)
{
if ( arry[k] ==32)
{
k++;
word[i][j] ='\0';
break;
}
else
{
word[i][j] = arry[k];
}
k++;
}
}
for (i=0;i<4;i++)
{
t = word[i];
while (*t)
{
printf("%c",*t);
t++;
}
printf("\n");
}
for (i=0;i<4;i++)
{
t = word[i];
while (*t)
{
t++;
Max++;
}
Len[i]=Max;
printf("%d \n",Max);
Max =0;
}
printf("OK\n");
Max=Len[0];
for(i=0;i<4;i++)
{
if(Max<Len[i])
{
Max = Len[i];
biao = i;
}
}
printf("最大值:%d,下标为:%d\n",Max,biao);
printf("即第%d个单词:",biao+1);
for (i=0;i<6;i++)
{
printf("%c",word[3][i]);
}
printf(" 最长。\n");
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询