24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 542  |  回复: 0

樱木三道

新虫 (著名写手)

[求助] 程序求助

我的程序采用读取文件数据自动赋值计算,m存放在map容器中,下一次输入计算后,在map中搜索jiao1,如果有jiao1相对的就jie1相加。我刚开始是手动输入,第一次输入与第二次输入有叠加,实现了我的功能,但是现在改为读取文件数据后,最后的结果只是最后一次计算的结果。这个是程序逻辑出错了吗?(可能程序计算公式较多,看起来较麻烦,可以只看程序整体逻辑关系)

#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include <map>
#include <iostream>
#include <sstream>
#include <fstream>
#include <string>
using namespace std;
map<float,float> g_mapData;
void insert_map(float jie1,float jiao1)
{
        if (g_mapData.find(jiao1) != g_mapData.end() )
        {
                float jie = g_mapData[jiao1];
                g_mapData[jiao1] = jie + jie1;
        }else
                g_mapData[jiao1]= jie1;
}
void str2int(int &int_temp,const string &string_temp)
{
        stringstream stream(string_temp);
        stream>>int_temp;
}
int main(int args, char **argv)
{
        std::ifstream fin("split.txt", std::ios::in);
        char line[1024]={0};
        std::string X = "";
        std::string Y = "";
        std::string Z = "";
        while(fin.getline(line, sizeof(line)))
        {
                std::stringstream word(line);
                word >> X;
                word >> Y;
                word >> Z;
                std::cout << "X: " << X << std::endl;
                std::cout << "Y: " << Y << std::endl;
                std::cout << "Z: " << Z << std::endl;

                string str = X;
                int nX = 0;
                str2int(nX,str);

                str = Y;
                int nY = 0;
                str2int(nY,str);

                str = Z;
                int nZ = 0;
                str2int(nZ,str);

                std::ifstream fin("split1.txt", std::ios::in);
        char line[1024]={0};
        std::string X1 = "";
        std::string Y1 = "";
        std::string Z1 = "";
        while(fin.getline(line, sizeof(line)))
        {
                std::stringstream word(line);
                word >> X1;
                word >> Y1;
                word >> Z1;
                std::cout << "X1: " << X1 << std::endl;
                std::cout << "Y1: " << Y1 << std::endl;
                std::cout << "Z1: " << Z1 << std::endl;

                string str = X1;
                int nX1 = 0;
                str2int(nX1,str);

                str = Y1;
                int nY1 = 0;
                str2int(nY1,str);

                str = Z1;
                int nZ1 = 0;
                str2int(nZ1,str);

                int n;
                double b,c,d,e,f,jit,ji1,sum,jiw,xiangliangx,xiangliangy,zongjiao;
                sum=0;
                jiw=0;
               
                b=nX1;
                c=4;
                d=4;
                e=2;
                f=2;
                double x=fabs(nX-c);

                double y=fabs(b-d);

                double j=sqrt(x*x+y*y);

                double h=e+f;

                if(j<h)

                {
                        double A;

                        A=(e*e+j*j-f*f)/(2*j*e);

                        double ji=0;

                        ji=acos(A);

                        ji=ji/3.1415926*180;
                        int jir=int(ji);

                        ji=jir;
                        jit= ji/180*3.1415926;
                        n=ji/1;
                        printf("与第一个圆的夹角%lf\n",ji);
                        xiangliangx=c-nX;
                        xiangliangy=d-b;

                        if(xiangliangy>0)
                                if(xiangliangx>0)
                                        zongjiao=atan(xiangliangy/xiangliangx);

                                else
                                        zongjiao=atan(-xiangliangy/xiangliangx)+3.1415926/2;

                        else
                                if(xiangliangx>0)
                                        zongjiao=atan(xiangliangy/xiangliangx);
                                else
                                        zongjiao=atan(-xiangliangy/xiangliangx)-3.1415926/2;
                        zongjiao = int(zongjiao/3.1415926*180);
                        zongjiao=zongjiao/180*3.1415926;
                        for(int i=1;i<n;i++)
                        {
                                double x1,x2,x3,jieg1,jieg2,jieg,B,jie0,jie1,jiao1,jiao2,jiao;
                                B=jit/n;
                                x1=1+tan(i*B)*tan(i*B);
                                x2=-2*j;
                                x3=j*j-f*f;
                                jieg1=(-x2+sqrt(x2*x2-4*x1*x3))/(2*x1);
                                jieg2=jieg1*tan(i*B);
                                jieg=sqrt(jieg1*jieg1+jieg2*jieg2);

                                jie0=(jieg-2);
                                jiao1=(zongjiao+B*i)/3.1415926*180;
                                jiao2=(zongjiao-B*i)/3.1415926*180;
                                jiao=i*B/3.1415926*180;

                                jie1=pow(jie0,1.5)*cos(i*B)*f;
                                sum=sum+jie1;
                                printf("输出A%d=%lf\n",i+1,jie1);
                                printf("输出角A%d=%lf\n",i+1,jiao1);
                                printf("输出角A%d=%lf\n",i+1,jiao2);
                                insert_map(jie1,jiao1);
                        }
                }
                else
                        printf("两圆无交点";

                }
       
        }
        system("pause";
        return 0;
}
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 樱木三道 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 348求调剂 +4 吴彦祖24k 2026-04-02 4/200 2026-04-02 12:46 by wxiongid
[考研] 265求调剂 +8 林深温澜 2026-04-01 10/500 2026-04-02 11:35 by Sammy2
[考研] 计算机265跨调环境 +5 Yumeng_6 2026-03-27 5/250 2026-04-02 10:54 by guanxin1001
[考研] 303求调剂 +8 DLkz1314. 2026-03-30 8/400 2026-04-02 09:08 by sanrepian
[考研] 一志愿南昌大学324求调剂 +11 hanamiko 2026-04-01 11/550 2026-04-02 09:00 by sanrepian
[考研] 求生物学调剂 +8 15172915737 2026-04-01 8/400 2026-04-02 06:49 by ilovexiaobin
[考研] 296求调剂 +4 汪!?! 2026-03-31 7/350 2026-04-01 22:04 by 客尔美德
[考研] 070300一志愿211,312分求调剂院校 +14 小黄鸭宝 2026-03-30 14/700 2026-04-01 20:19 by 赖春艳
[考研] 290求调剂 +5 dfffsar 2026-03-29 5/250 2026-04-01 19:45 by 6781022
[考研] 303分 0807学硕求调剂 +3 TYC3632 2026-04-01 3/150 2026-04-01 19:24 by lwk2004
[考研] 一志愿郑大085600,310分求调剂 +6 李潇可 2026-03-26 6/300 2026-04-01 14:44 by chenqifeng666
[考研] 调剂申请 +8 张张张张zy 2026-03-31 9/450 2026-04-01 08:29 by zjbkx
[考研] 合肥区域性重点一本招收调剂 +4 6266jl 2026-03-30 8/400 2026-03-31 18:43 by 6266jl
[考研] 329求调剂,一志愿西北工业大学,材料工程(085601) +6 小小机灵虫 2026-03-29 12/600 2026-03-31 16:58 by 记事本2026
[考研] 08工科,295,接受跨专业调剂 +6 lmnlzy 2026-03-30 6/300 2026-03-31 10:04 by cal0306
[考研] 吉大生物学326分求调剂 +3 sunnyupup 2026-03-31 3/150 2026-03-31 09:28 by longlotian
[考研] 22408 359分调剂 +4 Qshers 2026-03-27 8/400 2026-03-31 08:53 by Qshers
[考研] 285求调剂 +6 AZMK 2026-03-29 9/450 2026-03-30 21:02 by dophin1985
[考研] 332求92调剂 +8 蕉蕉123 2026-03-28 8/400 2026-03-29 10:46 by 周梓丹
[考研] 298求调剂 +4 种圣赐 2026-03-28 4/200 2026-03-29 08:42 by q1092522407
信息提示
请填处理意见