2 halogio halogio 于 2016.01.13 15:09 提问

C语言一个简单程序设计问题,找不出原因。

这段程序是为了输入一个月份(英文单词),然后返回截止到输入月份的所有月的天数总和(比如我输入march,则返回1-3月份天数总和)。函数部分的功能是如果月份输入正确,就返回总数。如果输入不正确,那就返回-1。但是运行程序后,每次运行函数都是返回-1。不知道哪里出了问题,麻烦大家看下。谢谢。

代码如下:
#include
#include
#include

int days(char *p);
struct month{
char name[10];
char abbrev[4];
int days;
int monumb;
};

struct month months[12]={
{"january", "jan",31,1},
{"february", "feb",28,2},
{"march", "mar",31,3},
{"april", "apr",30,4},
{"may", "may",31,5},
{"june", "jun",30,6},
{"july", "jul",31,7},
{"august", "aug",31,8},
{"september", "sep",30,9},
{"october", "oct",31,10},
{"november", "nov",30,11},
{"december", "dec",31,12}
};


int main(void)
{
char input[10];
int daytotal;
printf("PLS enter the month");
while(fgets(input,100,stdin)!=NULL&&input[0]!='\0')
{
daytotal=days(input);
if(daytotal>0)
printf("The total days is %d.",daytotal);
else
printf("Input is not valid,pls enter again.\n");
puts("pls enter the next input");
}
return 0;
}


int days(char p) _*函数部分**_
{
int i=0;
int total=0;
while( p[i] != '\0' )
{
p[i] = tolower( p[i] );
i++;
}

 for(i=0;i<12;i++)
 {
 total += months[i].days ;
 if( strcmp( p, months[i].name) == 0 )
     return total;
 }
 return -1;

}

3个回答

qq_27183003
qq_27183003   Ds   Rxr 2016.01.13 15:35
已采纳

fgets每次读入时会把回车也放到字符串里,造成比较失败。修改如下:

    while(gets(input)!=NULL&&input[0]!='\0')

halogio
halogio 成功啦。 太感谢了。 因为vs下不能使用gets 我就换成fgets了。没想到是这里问题。 还是基础不牢固。麻烦了。
2 年多之前 回复
CSDNXIAOD
CSDNXIAOD   2016.01.13 15:11

c语言程序设计问题
----------------------biu~biu~biu~~~在下问答机器人小D,这是我依靠自己的聪明才智给出的答案,如果不正确,你来咬我啊!

qq_33480398
qq_33480398   2016.01.13 15:28

子函数括号里p是地址

halogio
halogio 不是这个原因呀 这里面没问题。 可以直接这样子用的。我还特意编了代码。 #include <stdio.h> #include <string.h> static int present_mode; static double distance; static double fule; int main(void) { char *ptr; char arr[81]="Nice to meet you."; char app[81]="Nice to meet you."; int judge; ptr=arr; judge=strcmp(ptr,app); printf("%d",judge); return 0; }
2 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
最小重量机器设计问题 回溯法
最小重量机器设计问题 问题描述:设某一机器由n个部件组成,每一种部件都可以从m个不同的供应商处购得。设wij是从供应商j处够来的部件i的重量,cij是相应的价格。 试设计一个算法,给出总价格不超过c的最小重量机器设计。     算法设计:对于给定的机器部件重量和机器部件价格,计算总价值不超过d的最小重量机器设计。    数据输入:第一行由3个正整数n,m,d。接下来的2n
回溯法 最小重量机器设计
描述 设某一机器由n个部件组成,每一种部件都可以从m个不同的供应商处购得。设wiy 是从供应商j 处购得的部件i的重量,ciy是相应的价格。试 设计一个算法,给出总价格不超过c的最小重量机器设计。 对于给定的机器部件重量和机器部件价格,编程计算总价格不超过d的最小重量机器设计。 输入  第一行有3 个正整数n ,m和d。接下来的2n 行,每行n个数。前n行是c,后n行是w
最小机器重量设计问题(回溯法-满m叉树)
1.问题描述:        设某一机器由n个部件组成,每一种部件都可以从m个不同的供应商处购得。设 wij 是从供应商j 处购得的部件i的重量,cij 是相应的价格。 试设计一个回溯算法,对于给定的机器部件重量和机器部件价格,计算总价格不超过c的最小重量机器设计。 2.算法设计:        回溯法要求要给出约束条件,很明显:总价格不超过c, 设当前已选部件的重量
C语言学习笔记(一)—— 初识C语言并写一个简单的C语言程序
1、目标代码文件、可执行文件、库用C语言编写程序时,编写的内容被存储在文本文件中,该文件被称为源代码文件,文件以.c结尾。目标文件和可执行文件都是由机器语言指令组成的,但是目标文件只包含编译器为你编写的代码翻译的机器语言代码,可执行文件还包含你编写的程序中使用的库函数和启动代码的机器代码。2、链接器的作用将你编写的目标代码、系统的标准启动代码和库代码这3部分合并成一个文件,即可执行文件。3、在li...
最小重量机器设计问题——优先队列式分支限界法
本代码运用优先队列式分支限界法解决了最小重量机器设计问题。 算法思路: 对于在某一个供应商是否购买某一零件,可以将这个过程抽象化为子集树模型。该树的第i层则代表第i个零件的购买情况,每个商家j对应一棵子树。从根节点开始,对于当前讨论的节点我们将之当作扩展节点,遍历该扩展节点的所有子节点,将其中符合条件的子节点全部插入优先队列中(判断条件运用剪枝函数,下面讨论)。当遍历完后,该节点成为死节点,从优先队列中取出在当前情况下重量最小的节点继续向下进行迭代,直到到达某叶子节点后,记录下当前情况下的最小重量,然后继续
12.3 C语言指针的简单示例
前边我们提到了,指针的意义往往在小程序里是体现不出来的,对于简单程序来说,有时候用了指针,反而可能比没用指针还麻烦,但是为了让大家巩固一下指针的用法,我还是写了个使用指针的流水灯程序,目的是让大家从简单程序开始了解指针,当程序复杂的时候不至于手足无措。 #include sbit ADDR0 = P1^0;sbit ADDR1 = P1^1;sbit ADDR2 = P1^2;sbit
最小重量机器问题报告
对于最小重量机器设计问题,设计其回溯算法和分支限界算法的解决方案,并体会回溯方法和分支限界方法的区别。
编写最简单C语言程序
#include<stdio.h> void main() { printf("This is a sample of c program.\n"); }
回溯法算法思想解决最小机器重量设计问题
开门见山 简单理解回溯法 最小机器重量问题处理 一、回溯法 1.基本概念:     (1)回溯法     回溯算法是一种选优搜索法,按选优条件向前搜索,以达到目标。简单的说是在搜索过程中寻找问题的解,当发现已不满足求解条件时,就回溯返回,尝试别的路径。     当探索到某一步时,发现原先选择不是目前的最优解或不满足问题条件时,就退回一步重新选择,并减去当前步骤的节点对应的值,这种
最小重量机器设计问题
一、实验目的 1、了解回溯法和分支限界法的基本思想。 2、运用回溯法和分支限界法解决最小重量机器设计问题。 二、实验要求 最小重量机器设计问题:设某一机器由n个部件组成,每一种部件可以从m个不同的供应商处购得。设wij是从供应商j处购得的部件i的重量,cij是相应的价格。试设计一个算法,给出总价格不超过c的最小重量机器设计。分别用回溯法和分支限界法实现问题的算法